<?xml version="1.0"?>
<doc>
    <assembly>
        <name>ObjectListView</name>
    </assembly>
    <members>
        <member name="T:BrightIdeasSoftware.DataTreeListView">
            <summary>
            A DataTreeListView is a TreeListView that calculates its hierarchy based on
            information in the data source.
            </summary>
            <remarks>
            <para>Like a <see cref="T:BrightIdeasSoftware.DataListView"/>, a DataTreeListView sources all its information
            from a combination of <see cref="P:BrightIdeasSoftware.DataTreeListView.DataSource"/> and <see cref="P:BrightIdeasSoftware.DataTreeListView.DataMember"/>. 
            <see cref="P:BrightIdeasSoftware.DataTreeListView.DataSource"/> can be a DataTable, DataSet,
            or anything that implements <see cref="T:System.Collections.IList"/>. 
            </para>
            <para>
            To function properly, the DataTreeListView requires:
            <list type="bullet">
            <item>the table to have a column which holds a unique for the row. The name of this column must be set in <see cref="P:BrightIdeasSoftware.DataTreeListView.KeyAspectName"/>.</item>
            <item>the table to have a column which holds id of the hierarchical parent of the row. The name of this column must be set in <see cref="P:BrightIdeasSoftware.DataTreeListView.ParentKeyAspectName"/>.</item>
            <item>a value which identifies which rows are the roots of the tree (<see cref="P:BrightIdeasSoftware.DataTreeListView.RootKeyValue"/>).</item>
            </list>
            The hierarchy structure is determined finding all the rows where the parent key is equal to <see cref="P:BrightIdeasSoftware.DataTreeListView.RootKeyValue"/>. These  rows
            become the root objects of the hierarchy.
            </para>
            <para>Like a TreeListView, the hierarchy must not contain cycles. Bad things will happen if the data is cyclic.</para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView">
            <summary>
            A TreeListView combines an expandable tree structure with list view columns.
            </summary>
            <remarks>
            <para>To support tree operations, two delegates must be provided:</para>
            <list type="table">
            <item>
            <term>
            CanExpandGetter
            </term> 
            <description>
            This delegate must accept a model object and return a boolean indicating
            if that model should be expandable. 
            </description>
            </item>
            <item>
            <term>
            ChildrenGetter
            </term> 
            <description>
            This delegate must accept a model object and return an IEnumerable of model
            objects that will be displayed as children of the parent model. This delegate will only be called
            for a model object if the CanExpandGetter has already returned true for that model.
            </description>
            </item>
            <item>
            <term>
            ParentGetter
            </term> 
            <description>
            This delegate must accept a model object and return the parent model. 
            This delegate will only be called when HierarchicalCheckboxes is true OR when Reveal() is called. 
            </description>
            </item>
            </list>
            <para>
            The top level branches of the tree are set via the Roots property. SetObjects(), AddObjects() 
            and RemoveObjects() are interpreted as operations on this collection of roots.
            </para>
            <para>
            To add new children to an existing branch, make changes to your model objects and then
            call RefreshObject() on the parent.
            </para>
            <para>The tree must be a directed acyclic graph -- no cycles are allowed. Put more mundanely, 
            each model object must appear only once in the tree. If the same model object appears in two
            places in the tree, the control will become confused.</para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.VirtualObjectListView">
            <summary>
            A virtual object list view operates in virtual mode, that is, it only gets model objects for
            a row when it is needed. This gives it the ability to handle very large numbers of rows with
            minimal resources.
            </summary>
            <remarks><para>A listview is not a great user interface for a large number of items. But if you've
            ever wanted to have a list with 10 million items, go ahead, knock yourself out.</para>
            <para>Virtual lists can never iterate their contents. That would defeat the whole purpose.</para>
            <para>Animated GIFs should not be used in virtual lists. Animated GIFs require some state
            information to be stored for each animation, but virtual lists specifically do not keep any state information.
            In any case, you really do not want to keep state information for 10 million animations!</para>
            <para>
            Although it isn't documented, .NET virtual lists cannot have checkboxes. This class codes around this limitation,
            but you must use the functions provided by ObjectListView: CheckedObjects, CheckObject(), UncheckObject() and their friends. 
            If you use the normal check box properties (CheckedItems or CheckedIndicies), they will throw an exception, since the
            list is in virtual mode, and .NET "knows" it can't handle checkboxes in virtual mode.
            </para>
            <para>Due to the limits of the underlying Windows control, virtual lists do not trigger ItemCheck/ItemChecked events. 
            Use a CheckStatePutter instead.</para>
            <para>To enable grouping, you must provide an implmentation of IVirtualGroups interface, via the GroupingStrategy property.</para>
            <para>Similarly, to enable filtering on the list, your VirtualListDataSource must also implement the IFilterableDataSource interface.</para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.ObjectListView">
            <summary>
            An ObjectListView is a much easier to use, and much more powerful, version of the ListView.
            </summary>
            <remarks>
            <para>
            An ObjectListView automatically populates a ListView control with information taken 
            from a given collection of objects. It can do this because each column is configured
            to know which bit of the model object (the "aspect") it should be displaying. Columns similarly
            understand how to sort the list based on their aspect, and how to construct groups
            using their aspect.
            </para>
            <para>
            Aspects are extracted by giving the name of a method to be called or a
            property to be fetched. These names can be simple names or they can be dotted
            to chain property access e.g. "Owner.Address.Postcode".
            Aspects can also be extracted by installing a delegate.
            </para>
            <para>
            An ObjectListView can show a "this list is empty" message when there is nothing to show in the list, 
            so that the user knows the control is supposed to be empty.
            </para>
            <para>
            Right clicking on a column header should present a menu which can contain:
            commands (sort, group, ungroup); filtering; and column selection. Whether these
            parts of the menu appear is controlled by ShowCommandMenuOnRightClick, 
            ShowFilterMenuOnRightClick and SelectColumnsOnRightClick respectively.
            </para>
            <para>
            The groups created by an ObjectListView can be configured to include other formatting
            information, including a group icon, subtitle and task button. Using some undocumented
            interfaces, these groups can even on virtual lists.
            </para>
            <para>
            ObjectListView supports dragging rows to other places, including other application. 
            Special support is provide for drops from other ObjectListViews in the same application. 
            In many cases, an ObjectListView becomes a full drag source by setting <see cref="P:BrightIdeasSoftware.ObjectListView.IsSimpleDragSource"/> to 
            true. Similarly, to accept drops, it is usually enough to set <see cref="P:BrightIdeasSoftware.ObjectListView.IsSimpleDropSink"/> to true, 
            and then handle the <see cref="E:BrightIdeasSoftware.ObjectListView.CanDrop"/>  and <see cref="E:BrightIdeasSoftware.ObjectListView.Dropped"/>  events (or the <see cref="E:BrightIdeasSoftware.ObjectListView.ModelCanDrop"/>  and 
            <see cref="E:BrightIdeasSoftware.ObjectListView.ModelDropped"/> events, if you only want to handle drops from other ObjectListViews in your application).
            </para>
            <para>
            For these classes to build correctly, the project must have references to these assemblies:
            </para>
            <list type="bullet">
            <item><description>System</description></item>
            <item><description>System.Data</description></item>
            <item><description>System.Design</description></item>
            <item><description>System.Drawing</description></item>
            <item><description>System.Windows.Forms (obviously)</description></item>
            </list>
            </remarks>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.SORT_INDICATOR_UP_KEY">
            <summary>
            The name of the image used when a column is sorted ascending
            </summary>
            <remarks>This image is only used on pre-XP systems. System images are used for XP and later</remarks>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.SORT_INDICATOR_DOWN_KEY">
            <summary>
            The name of the image used when a column is sorted descending
            </summary>
            <remarks>This image is only used on pre-XP systems. System images are used for XP and later</remarks>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.CHECKED_KEY">
            <summary>
            The name of the image used when a check box is checked
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.UNCHECKED_KEY">
            <summary>
            The name of the image used when a check box is unchecked
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.INDETERMINATE_KEY">
            <summary>
            The name of the image used when a check box is Indeterminate
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnAboutToCreateGroups(BrightIdeasSoftware.CreateGroupsEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnBeforeCreatingGroups(BrightIdeasSoftware.CreateGroupsEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnAfterCreatingGroups(BrightIdeasSoftware.CreateGroupsEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnAfterSearching(BrightIdeasSoftware.AfterSearchingEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnAfterSorting(BrightIdeasSoftware.AfterSortingEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnBeforeSearching(BrightIdeasSoftware.BeforeSearchingEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnBeforeSorting(BrightIdeasSoftware.BeforeSortingEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnCanDrop(BrightIdeasSoftware.OlvDropEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnCellClick(BrightIdeasSoftware.CellClickEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnCellOver(BrightIdeasSoftware.CellOverEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnCellRightClick(BrightIdeasSoftware.CellRightClickEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnCellToolTip(BrightIdeasSoftware.ToolTipShowingEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnSubItemChecking(BrightIdeasSoftware.SubItemCheckingEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnColumnRightClick(System.Windows.Forms.ColumnClickEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnDropped(BrightIdeasSoftware.OlvDropEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnFilter(BrightIdeasSoftware.FilterEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnFormatCell(BrightIdeasSoftware.FormatCellEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnFormatRow(BrightIdeasSoftware.FormatRowEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnFreezing(BrightIdeasSoftware.FreezeEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnGroupExpandingCollapsing(BrightIdeasSoftware.GroupExpandingCollapsingEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnGroupStateChanged(BrightIdeasSoftware.GroupStateChangedEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnHeaderToolTip(BrightIdeasSoftware.ToolTipShowingEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnHotItemChanged(BrightIdeasSoftware.HotItemChangedEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnHyperlinkClicked(BrightIdeasSoftware.HyperlinkClickedEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnGroupTaskClicked(BrightIdeasSoftware.GroupTaskClickedEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnIsHyperlink(BrightIdeasSoftware.IsHyperlinkEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnItemsAdding(BrightIdeasSoftware.ItemsAddingEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnItemsChanged(BrightIdeasSoftware.ItemsChangedEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnItemsChanging(BrightIdeasSoftware.ItemsChangingEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnItemsRemoving(BrightIdeasSoftware.ItemsRemovingEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnModelCanDrop(BrightIdeasSoftware.ModelDropEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnModelDropped(BrightIdeasSoftware.ModelDropEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnSelectionChanged(System.EventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnScroll(System.Windows.Forms.ScrollEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnCellEditStarting(BrightIdeasSoftware.CellEditEventArgs)">
            <summary>
            Tell the world when a cell is about to be edited.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnCellEditorValidating(BrightIdeasSoftware.CellEditEventArgs)">
            <summary>
            Tell the world when a cell is about to finish being edited.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnCellEditFinishing(BrightIdeasSoftware.CellEditEventArgs)">
            <summary>
            Tell the world when a cell is about to finish being edited.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.#ctor">
            <summary>
            Create an ObjectListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Dispose(System.Boolean)">
            <summary>
            Dispose of any resources this instance has been using
            </summary>
            <param name="disposing"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EnumerableToArray(System.Collections.IEnumerable,System.Boolean)">
            <summary>
            Convert the given enumerable into an ArrayList as efficiently as possible
            </summary>
            <param name="collection">The source collection</param>
            <param name="alwaysCreate">If true, this method will always create a new
            collection.</param>
            <returns>An ArrayList with the same contents as the given collection.</returns>
            <remarks>
            <para>When we move to .NET 3.5, we can use LINQ and not need this method.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EnumerableCount(System.Collections.IEnumerable)">
            <summary>
            Return the count of items in the given enumerable
            </summary>
            <param name="collection"></param>
            <returns></returns>
            <remarks>When we move to .NET 3.5, we can use LINQ and not need this method.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.IsEnumerableEmpty(System.Collections.IEnumerable)">
            <summary>
            Return whether or not the given enumerable is empty. A string is regarded as 
            an empty collection.
            </summary>
            <param name="collection"></param>
            <returns>True if the given collection is null or empty</returns>
            <remarks>
            <para>When we move to .NET 3.5, we can use LINQ and not need this method.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.IsDisabled(System.Object)">
            <summary>
            Is this given model object disabled?
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.DisableObject(System.Object)">
            <summary>
            Disable the given model object.
            Disabled objects cannot be selected or activated.
            </summary>
            <param name="model">Must not be null</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.DisableObjects(System.Collections.IEnumerable)">
            <summary>
            Disable all the given model objects
            </summary>
            <param name="models"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EnableObject(System.Object)">
            <summary>
            Enable the given model object, so it can be selected and activated again.
            </summary>
            <param name="model">Must not be null</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EnableObjects(System.Collections.IEnumerable)">
            <summary>
            Enable all the given model objects
            </summary>
            <param name="models"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ClearDisabledObjects">
            <summary>
            Forget all disabled objects. This does not trigger a redraw or rebuild
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.EditorRegistry">
            <summary>
            This registry decides what control should be used to edit what cells, based
            on the type of the value in the cell.
            </summary>
            <see cref="F:BrightIdeasSoftware.ObjectListView.EditorRegistry"/>
            <remarks>All instances of ObjectListView share the same editor registry.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.AddObject(System.Object)">
            <summary>
            Add the given model object to this control.
            </summary>
            <param name="modelObject">The model object to be displayed</param>
            <remarks>See AddObjects() for more details</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.AddObjects(System.Collections.ICollection)">
            <summary>
            Add the given collection of model objects to this control.
            </summary>
            <param name="modelObjects">A collection of model objects</param>
            <remarks>
            <para>The added objects will appear in their correct sort position, if sorting
            is active (i.e. if PrimarySortColumn is not null). Otherwise, they will appear at the end of the list.</para>
            <para>No check is performed to see if any of the objects are already in the ListView.</para>
            <para>Null objects are silently ignored.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.AutoResizeColumns">
            <summary>
            Resize the columns to the maximum of the header width and the data.
            </summary>		
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.AutoSizeColumns">
            <summary>
            Set up any automatically initialized column widths (columns that 
            have a width of 0 or -1 will be resized to the width of their 
            contents or header respectively).
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.BuildGroups">
            <summary>
            Organise the view items into groups, based on the last sort column or the first column
            if there is no last sort column
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.BuildGroups(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Organise the view items into groups, based on the given column
            </summary>
            <remarks>
            <para>
            If the AlwaysGroupByColumn property is not null,
            the list view items will be organisd by that column,
            and the 'column' parameter will be ignored.
            </para>
            <para>This method triggers sorting events: BeforeSorting and AfterSorting.</para>
            </remarks>
            <param name="column">The column whose values should be used for sorting.</param>
            <param name="order"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.BuildGroups(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Organise the view items into groups, based on the given columns
            </summary>
            <param name="groupByColumn">What column will be used for grouping</param>
            <param name="groupByOrder">What ordering will be used for groups</param>
            <param name="column">The column whose values should be used for sorting. Cannot be null</param>
            <param name="order">The order in which the values from column will be sorted</param>
            <param name="secondaryColumn">When the values from 'column' are equal, use the values provided by this column</param>
            <param name="secondaryOrder">How will the secondary values be sorted</param>
            <remarks>This method does not trigger sorting events. Use BuildGroups() to do that</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CollectGroupingParameters(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Collect and return all the variables that influence the creation of groups
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeGroups(BrightIdeasSoftware.GroupingParameters)">
            <summary>
            Make a list of groups that should be shown according to the given parameters
            </summary>
            <param name="parms"></param>
            <returns>The list of groups to be created</returns>
            <remarks>This should not change the state of the control. It is possible that the
            groups created will not be used. They may simply be discarded.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.BuildList">
            <summary>
            Build/rebuild all the list view items in the list, preserving as much state as is possible
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.BuildList(System.Boolean)">
            <summary>
            Build/rebuild all the list view items in the list
            </summary>
            <param name="shouldPreserveState">If this is true, the control will try to preserve the selection,
            focused item, and the scroll position (see Remarks)
            </param>
            <remarks>
            <para>
            Use this method in situations were the contents of the list is basically the same
            as previously.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ClearCachedInfo">
            <summary>
            Clear any cached info this list may have been using
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ApplyExtendedStyles">
            <summary>
            Apply all required extended styles to our control.
            </summary>
            <remarks>
            <para>
            Whenever .NET code sets an extended style, it erases all other extended styles
            that it doesn't use. So, we have to explicit reapply the styles that we have
            added.
            </para>
            <para>
            Normally, we would override CreateParms property and update
            the ExStyle member, but ListView seems to ignore all ExStyles that
            it doesn't already know about. Worse, when we set the LVS_EX_HEADERINALLVIEWS 
            value, bad things happen (the control crashes!).
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CalculateReasonableTileSize">
            <summary>
            Give the listview a reasonable size of its tiles, based on the number of lines of
            information that each tile is going to display.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ChangeToFilteredColumns(System.Windows.Forms.View)">
            <summary>
            Rebuild this list for the given view
            </summary>
            <param name="view"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ClearObjects">
            <summary>
            Remove all items from this list
            </summary>
            <remark>This method can safely be called from background threads.</remark>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ClearUrlVisited">
            <summary>
            Reset the memory of which URLs have been visited
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CopySelectionToClipboard">
            <summary>
            Copy a text and html representation of the selected rows onto the clipboard.
            </summary>
            <remarks>Be careful when using this with virtual lists. If the user has selected
            10,000,000 rows, this method will faithfully try to copy all of them to the clipboard.
            From the user's point of view, your program will appear to have hung.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CopyObjectsToClipboard(System.Collections.IList)">
            <summary>
            Copy a text and html representation of the given objects onto the clipboard.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ObjectsToHtml(System.Collections.IList)">
            <summary>
            Return a html representation of the given objects
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.DeselectAll">
            <summary>
            Deselect all rows in the listview
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EnableCustomSelectionColors">
            <summary>
            Setup the list so it will draw selected rows using custom colours.
            </summary>
            <remarks>
            This method makes the list owner drawn, and ensures that all columns have at
            least a BaseRender installed.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetNextItem(BrightIdeasSoftware.OLVListItem)">
            <summary>
            Return the ListViewItem that appears immediately after the given item.
            If the given item is null, the first item in the list will be returned.
            Return null if the given item is the last item.
            </summary>
            <param name="itemToFind">The item that is before the item that is returned, or null</param>
            <returns>A ListViewItem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetLastItemInDisplayOrder">
            <summary>
            Return the last item in the order they are shown to the user.
            If the control is not grouped, the display order is the same as the
            sorted list order. But if the list is grouped, the display order is different.
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetNthItemInDisplayOrder(System.Int32)">
            <summary>
            Return the n'th item (0-based) in the order they are shown to the user.
            If the control is not grouped, the display order is the same as the
            sorted list order. But if the list is grouped, the display order is different.
            </summary>
            <param name="n"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetDisplayOrderOfItemIndex(System.Int32)">
            <summary>
            Return the display index of the given listviewitem index.
            If the control is not grouped, the display order is the same as the
            sorted list order. But if the list is grouped, the display order is different.
            </summary>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetPreviousItem(BrightIdeasSoftware.OLVListItem)">
            <summary>
            Return the ListViewItem that appears immediately before the given item.
            If the given item is null, the last item in the list will be returned.
            Return null if the given item is the first item.
            </summary>
            <param name="itemToFind">The item that is before the item that is returned</param>
            <returns>A ListViewItem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.InsertObjects(System.Int32,System.Collections.ICollection)">
             <summary>
             Insert the given collection of objects before the given position
             </summary>
             <param name="index">Where to insert the objects</param>
             <param name="modelObjects">The objects to be inserted</param>
             <remarks>
             <para>
             This operation only makes sense of non-sorted, non-grouped
             lists, since any subsequent sort/group operation will rearrange
             the list.
             </para>
             <para>This method only works on ObjectListViews and FastObjectListViews.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.IsSelected(System.Object)">
            <summary>
            Return true if the row representing the given model is selected
            </summary>
            <param name="model">The model object to look for</param>
            <returns>Is the row selected</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.IsUrlVisited(System.String)">
            <summary>
            Has the given URL been visited?
            </summary>
            <param name="url">The string to be consider</param>
            <returns>Has it been visited</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.LowLevelScroll(System.Int32,System.Int32)">
            <summary>
            Scroll the ListView by the given deltas.
            </summary>
            <param name="dx">Horizontal delta</param>
            <param name="dy">Vertical delta</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MarkUrlVisited(System.String)">
            <summary>
            Remember that the given URL has been visited
            </summary>
            <param name="url">The url to be remembered</param>
            <remarks>This does not cause the control be redrawn</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MoveObjects(System.Int32,System.Collections.ICollection)">
            <summary>
            Move the given collection of objects to the given index.
            </summary>
            <remarks>This operation only makes sense on non-grouped ObjectListViews.</remarks>
            <param name="index"></param>
            <param name="modelObjects"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HitTest(System.Int32,System.Int32)">
            <summary>
            Calculate what item is under the given point?
            </summary>
            <param name="x"></param>
            <param name="y"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.LowLevelHitTest(System.Int32,System.Int32)">
            <summary>
            Perform a hit test using the Windows control's SUBITEMHITTEST message.
            This provides information about group hits that the standard ListView.HitTest() does not.
            </summary>
            <param name="x"></param>
            <param name="y"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OlvHitTest(System.Int32,System.Int32)">
            <summary>
            What is under the given point? This takes the various parts of a cell into accout, including
            any custom parts that a custom renderer might use
            </summary>
            <param name="x"></param>
            <param name="y"></param>
            <returns>An information block about what is under the point</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CalculateStandardHitTest(BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            Perform a hit test when the control is not owner drawn
            </summary>
            <param name="hti"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CalculateOwnerDrawnHitTest(BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            Perform a hit test when the control is owner drawn. This hands off responsibility
            to the renderer.
            </summary>
            <param name="hti"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.PauseAnimations(System.Boolean)">
            <summary>
            Pause (or unpause) all animations in the list
            </summary>
            <param name="isPause">true to pause, false to unpause</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RebuildColumns">
            <summary>
            Rebuild the columns based upon its current view and column visibility settings
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RemoveObject(System.Object)">
            <summary>
            Remove the given model object from the ListView
            </summary>
            <param name="modelObject">The model to be removed</param>
            <remarks>See RemoveObjects() for more details
            <para>This method is thread-safe.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RemoveObjects(System.Collections.ICollection)">
            <summary>
            Remove all of the given objects from the control.
            </summary>
            <param name="modelObjects">Collection of objects to be removed</param>
            <remarks>
            <para>Nulls and model objects that are not in the ListView are silently ignored.</para>
            <para>This method is thread-safe.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SelectAll">
            <summary>
            Select all rows in the listview
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetNativeBackgroundWatermark(System.Drawing.Image)">
            <summary>
            Set the given image to be fixed in the bottom right of the list view.
            This image will not scroll when the list view scrolls.
            </summary>
            <remarks>
            <para>
            This method uses ListView's native ability to display a background image.
            It has a few limitations: 
            </para>
            <list type="bullet">
            <item><description>It doesn't work well with owner drawn mode. In owner drawn mode, each cell draws itself,
            including its background, which covers the background image.</description></item>
            <item><description>It doesn't look very good when grid lines are enabled, since the grid lines are drawn over the image.</description></item>
            <item><description>It does not work at all on XP.</description></item>
            <item><description>Obviously, it doesn't look good when alternate row background colors are enabled.</description></item>
            </list>
            <para>
            If you can live with these limitations, native watermarks are quite neat. They are true backgrounds, not
            translucent overlays like the OverlayImage uses. They also have the decided advantage over overlays in that
            they work correctly even in MDI applications.
            </para>
            <para>Setting this clears any background image.</para>
            </remarks>
            <param name="image">The image to be drawn. If null, any existing image will be removed.</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetNativeBackgroundImage(System.Drawing.Image,System.Int32,System.Int32)">
            <summary>
            Set the given image to be background of the ListView so that it appears at the given
            percentage offsets within the list.
            </summary>
            <remarks>
            <para>This has the same limitations as described in <see cref="M:BrightIdeasSoftware.ObjectListView.SetNativeBackgroundWatermark(System.Drawing.Image)"/>. Make sure those limitations
            are understood before using the method.</para>
            <para>This is very similar to setting the <see cref="P:System.Windows.Forms.Control.BackgroundImage"/> property of the standard .NET ListView, except that the standard
            BackgroundImage does not handle images with transparent areas properly -- it renders transparent areas as black. This 
            method does not have that problem.</para>
            <para>Setting this clears any background watermark.</para>
            </remarks>
            <param name="image">The image to be drawn. If null, any existing image will be removed.</param>
            <param name="xOffset">The horizontal percentage where the image will be placed. 0 is absolute left, 100 is absolute right.</param>
            <param name="yOffset">The vertical percentage where the image will be placed.</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetNativeBackgroundTiledImage(System.Drawing.Image)">
            <summary>
            Set the given image to be the tiled background of the ListView.
            </summary>
            <remarks>
            <para>This has the same limitations as described in <see cref="M:BrightIdeasSoftware.ObjectListView.SetNativeBackgroundWatermark(System.Drawing.Image)"/> and <see cref="M:BrightIdeasSoftware.ObjectListView.SetNativeBackgroundImage(System.Drawing.Image,System.Int32,System.Int32)"/>.
            Make sure those limitations
            are understood before using the method.</para>
            </remarks>
            <param name="image">The image to be drawn. If null, any existing image will be removed.</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetObjects(System.Collections.IEnumerable)">
            <summary>
            Set the collection of objects that will be shown in this list view.
            </summary>
            <remark>This method can safely be called from background threads.</remark>
            <remarks>The list is updated immediately</remarks>
            <param name="collection">The objects to be displayed</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetObjects(System.Collections.IEnumerable,System.Boolean)">
            <summary>
            Set the collection of objects that will be shown in this list view.
            </summary>
            <remark>This method can safely be called from background threads.</remark>
            <remarks>The list is updated immediately</remarks>
            <param name="collection">The objects to be displayed</param>
            <param name="preserveState">Should the state of the list be preserved as far as is possible.</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateObject(System.Object)">
            <summary>
            Update the given model object into the ListView. The model will be added if it doesn't already exist.
            </summary>
            <param name="modelObject">The model to be updated</param>
            <remarks>
            <para>
            See <see cref="M:BrightIdeasSoftware.ObjectListView.RemoveObjects(System.Collections.ICollection)"/> for more details
            </para>
            <para>This method is thread-safe.</para>
            <para>This method will cause the list to be resorted.</para>
            <para>This method only works on ObjectListViews and FastObjectListViews.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateObjects(System.Collections.ICollection)">
            <summary>
            Update the pre-existing models that are equal to the given objects. If any of the model doesn't
            already exist in the control, they will be added.
            </summary>
            <param name="modelObjects">Collection of objects to be updated/added</param>
            <remarks>
            <para>This method will cause the list to be resorted.</para>
            <para>Nulls are silently ignored.</para>
            <para>This method is thread-safe.</para>
            <para>This method only works on ObjectListViews and FastObjectListViews.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateNotificationSubscriptions(System.Collections.IEnumerable)">
            <summary>
            Change any subscriptions to INotifyPropertyChanged events on our current
            model objects so that we no longer listen for events on the old models
            and do listen for events on the given collection.
            </summary>
            <remarks>This does nothing if UseNotifyPropertyChanged is false.</remarks>
            <param name="collection"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SubscribeNotifications(System.Collections.IEnumerable)">
            <summary>
            Subscribe to INotifyPropertyChanges on the given collection of objects.
            </summary>
            <param name="models"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UnsubscribeNotifications(System.Collections.IEnumerable)">
            <summary>
            Unsubscribe from INotifyPropertyChanges on the given collection of objects.
            If the given collection is null, unsubscribe from all current subscriptions
            </summary>
            <param name="models"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SaveState">
            <summary>
            Return a byte array that represents the current state of the ObjectListView, such
            that the state can be restored by RestoreState()
            </summary>
            <remarks>
            <para>The state of an ObjectListView includes the attributes that the user can modify:
            <list type="bullet">
            <item><description>current view (i.e. Details, Tile, Large Icon...)</description></item>
            <item><description>sort column and direction</description></item>
            <item><description>column order</description></item>
            <item><description>column widths</description></item>
            <item><description>column visibility</description></item>
            </list>
            </para>
            <para>
            It does not include selection or the scroll position.
            </para>
            </remarks>
            <returns>A byte array representing the state of the ObjectListView</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RestoreState(System.Byte[])">
            <summary>
            Restore the state of the control from the given string, which must have been
            produced by SaveState()
            </summary>
            <param name="state">A byte array returned from SaveState()</param>
            <returns>Returns true if the state was restored</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleApplicationIdle(System.Object,System.EventArgs)">
            <summary>
            The application is idle. Trigger a SelectionChanged event.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleApplicationIdleResizeColumns(System.Object,System.EventArgs)">
            <summary>
            The application is idle. Trigger a SelectionChanged event.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleBeginScroll(System.Windows.Forms.Message@)">
            <summary>
            Handle the BeginScroll listview notification
            </summary>
            <param name="m"></param>
            <returns>True if the event was completely handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleEndScroll(System.Windows.Forms.Message@)">
            <summary>
            Handle the EndScroll listview notification
            </summary>
            <param name="m"></param>
            <returns>True if the event was completely handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleLinkClick(System.Windows.Forms.Message@)">
            <summary>
            Handle the LinkClick listview notification
            </summary>
            <param name="m"></param>
            <returns>True if the event was completely handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleCellToolTipShowing(System.Object,BrightIdeasSoftware.ToolTipShowingEventArgs)">
            <summary>
            The cell tooltip control wants information about the tool tip that it should show.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HeaderToolTipShowingCallback(System.Object,BrightIdeasSoftware.ToolTipShowingEventArgs)">
            <summary>
            Allow the HeaderControl to call back into HandleHeaderToolTipShowing without making that method public
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleHeaderToolTipShowing(System.Object,BrightIdeasSoftware.ToolTipShowingEventArgs)">
            <summary>
            The header tooltip control wants information about the tool tip that it should show.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleColumnClick(System.Object,System.Windows.Forms.ColumnClickEventArgs)">
            <summary>
            Event handler for the column click event
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.WndProc(System.Windows.Forms.Message@)">
            <summary>
            Override the basic message pump for this control
            </summary>
            <param name="m"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleChar(System.Windows.Forms.Message@)">
            <summary>
            Handle the search for item m if possible.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleContextMenu(System.Windows.Forms.Message@)">
            <summary>
            The user wants to see the context menu.
            </summary>
            <param name="m">The windows m</param>
            <returns>A bool indicating if this m has been handled</returns>
            <remarks>
            We want to ignore context menu requests that are triggered by right clicks on the header
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleCustomDraw(System.Windows.Forms.Message@)">
            <summary>
            Handle the Custom draw series of notifications
            </summary>
            <param name="m">The message</param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleDestroy(System.Windows.Forms.Message@)">
            <summary>
            Handle the underlying control being destroyed
            </summary>
            <param name="m"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleFindItem(System.Windows.Forms.Message@)">
            <summary>
            Handle the search for item m if possible.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.FindMatchingRow(System.String,System.Int32,System.Windows.Forms.SearchDirectionHint)">
            <summary>
            Find the first row after the given start in which the text value in the
            comparison column begins with the given text. The comparison column is column 0,
            unless IsSearchOnSortColumn is true, in which case the current sort column is used.
            </summary>
            <param name="text">The text to be prefix matched</param>
            <param name="start">The index of the first row to consider</param>
            <param name="direction">Which direction should be searched?</param>
            <returns>The index of the first row that matched, or -1</returns>
            <remarks>The text comparison is a case-insensitive, prefix match. The search will
            search the every row until a match is found, wrapping at the end if needed.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.FindMatchInRange(System.String,System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Find the first row in the given range of rows that prefix matches the string value of the given column.
            </summary>
            <param name="text"></param>
            <param name="first"></param>
            <param name="last"></param>
            <param name="column"></param>
            <returns>The index of the matched row, or -1</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleGroupInfo(System.Windows.Forms.Message@)">
            <summary>
            Handle the Group Info series of notifications
            </summary>
            <param name="m">The message</param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleKeyDown(System.Windows.Forms.Message@)">
            <summary>
            Handle a key down message
            </summary>
            <param name="m"></param>
            <returns>True if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleLButtonDown(System.Windows.Forms.Message@)">
            <summary>
            Catch the Left Button down event.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ProcessLButtonDown(BrightIdeasSoftware.OlvListViewHitTestInfo)">
            <summary>
            Handle a left mouse down at the given hit test location
            </summary>
            <remarks>Subclasses can override this to do something unique</remarks>
            <param name="hti"></param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleLButtonUp(System.Windows.Forms.Message@)">
            <summary>
            Catch the Left Button up event.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.TriggerGroupExpandCollapse(BrightIdeasSoftware.OLVGroup)">
            <summary>
            Trigger a GroupExpandCollapse event and return true if the action was cancelled
            </summary>
            <param name="group"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleRButtonDown(System.Windows.Forms.Message@)">
            <summary>
            Catch the Right Button down event.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ProcessRButtonDown(BrightIdeasSoftware.OlvListViewHitTestInfo)">
            <summary>
            Handle a left mouse down at the given hit test location
            </summary>
            <remarks>Subclasses can override this to do something unique</remarks>
            <param name="hti"></param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleLButtonDoubleClick(System.Windows.Forms.Message@)">
            <summary>
            Catch the Left Button double click event.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ProcessLButtonDoubleClick(BrightIdeasSoftware.OlvListViewHitTestInfo)">
            <summary>
            Handle a mouse double click at the given hit test location
            </summary>
            <remarks>Subclasses can override this to do something unique</remarks>
            <param name="hti"></param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleRButtonDoubleClick(System.Windows.Forms.Message@)">
            <summary>
            Catch the right Button double click event.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ProcessRButtonDoubleClick(BrightIdeasSoftware.OlvListViewHitTestInfo)">
            <summary>
            Handle a right mouse double click at the given hit test location
            </summary>
            <remarks>Subclasses can override this to do something unique</remarks>
            <param name="hti"></param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleMouseMove(System.Windows.Forms.Message@)">
            <summary>
            Catch the MouseMove event.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleReflectNotify(System.Windows.Forms.Message@)">
            <summary>
            Handle notifications that have been reflected back from the parent window
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleNotify(System.Windows.Forms.Message@)">
            <summary>
            In the notification messages, we handle attempts to change the width of our columns
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CreateCellToolTip">
            <summary>
            Create a ToolTipControl to manage the tooltip control used by the listview control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateCellToolTipHandle">
            <summary>
            Update the handle used by our cell tooltip to be the tooltip used by
            the underlying Windows listview control.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandlePaint(System.Windows.Forms.Message@)">
            <summary>
            Handle the WM_PAINT event
            </summary>
            <param name="m"></param>
            <returns>Return true if the msg has been handled and nothing further should be done</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandlePrePaint">
            <summary>
            Perform any steps needed before painting the control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandlePostPaint">
            <summary>
            Perform any steps needed after painting the control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleWindowPosChanging(System.Windows.Forms.Message@)">
            <summary>
            Handle the window position changing.
            </summary>
            <param name="m">The m to be processed</param>
            <returns>bool to indicate if the msg has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleHeaderRightClick(System.Int32)">
            <summary>
            The user has right clicked on the column headers. Do whatever is required
            </summary>
            <returns>Return true if this event has been handle</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ShowHeaderRightClickMenu(System.Int32,System.Drawing.Point)">
            <summary>
            Show a menu that is appropriate when the given column header is clicked.
            </summary>
            <param name="columnIndex">The index of the header that was clicked. This
            can be -1, indicating that the header was clicked outside of a column</param>
            <param name="pt">Where should the menu be shown</param>
            <returns>True if a menu was displayed</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeHeaderRightClickMenu(System.Int32)">
            <summary>
            Create the menu that should be displayed when the user right clicks
            on the given column header.
            </summary>
            <param name="columnIndex">Index of the column that was right clicked.
            This can be negative, which indicates a click outside of any header.</param>
            <returns>The toolstrip that should be displayed</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleHeaderRightClick">
            <summary>
            The user has right clicked on the column headers. Do whatever is required
            </summary>
            <returns>Return true if this event has been handle</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ShowColumnSelectMenu(System.Drawing.Point)">
            <summary>
            Show a popup menu at the given point which will allow the user to choose which columns
            are visible on this listview
            </summary>
            <param name="pt">Where should the menu be placed</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ShowColumnCommandMenu(System.Int32,System.Drawing.Point)">
            <summary>
            Show a popup menu at the given point which will allow the user to choose which columns
            are visible on this listview
            </summary>
            <param name="columnIndex"></param>
            <param name="pt">Where should the menu be placed</param>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.SortAscendingImage">
            <summary>
            Gets or sets the image that will be place next to the Sort Ascending command
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.SortDescendingImage">
            <summary>
            Gets or sets the image that will be placed next to the Sort Descending command
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeColumnCommandMenu(System.Windows.Forms.ToolStripDropDown,System.Int32)">
            <summary>
            Append the column selection menu items to the given menu strip.
            </summary>
            <param name="strip">The menu to which the items will be added.</param>
            <param name="columnIndex"></param>
            <returns>Return the menu to which the items were added</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeColumnSelectMenu(System.Windows.Forms.ToolStripDropDown)">
            <summary>
            Append the column selection menu items to the given menu strip.
            </summary>
            <param name="strip">The menu to which the items will be added.</param>
            <returns>Return the menu to which the items were added</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.AddItemsToColumnSelectMenu(System.Windows.Forms.ToolStripItemCollection)">
            <summary>
            Create the menu items that will allow columns to be choosen and add them to the 
            given collection
            </summary>
            <param name="items"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeFilteringMenu(System.Windows.Forms.ToolStripDropDown,System.Int32)">
            <summary>
            Create a Filtering menu
            </summary>
            <param name="strip"></param>
            <param name="columnIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnColumnReordered(System.Windows.Forms.ColumnReorderedEventArgs)">
            <summary>
            Override the OnColumnReordered method to do what we want
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleColumnWidthChanging(System.Object,System.Windows.Forms.ColumnWidthChangingEventArgs)">
            <summary>
            When the column widths are changing, resize the space filling columns
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleColumnWidthChanged(System.Object,System.Windows.Forms.ColumnWidthChangedEventArgs)">
            <summary>
            When the column widths change, resize the space filling columns
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HandleLayout(System.Object,System.Windows.Forms.LayoutEventArgs)">
            <summary>
            When the size of the control changes, we have to resize our space filling columns.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ResizeFreeSpaceFillingColumns">
            <summary>
            Resize our space filling columns so they fill any unoccupied width in the control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ResizeFreeSpaceFillingColumns(System.Int32)">
            <summary>
            Resize our space filling columns so they fill any unoccupied width in the control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CheckIndeterminateObject(System.Object)">
            <summary>
            Mark the given object as indeterminate check state
            </summary>
            <param name="modelObject">The model object to be marked indeterminate</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CheckObject(System.Object)">
            <summary>
            Mark the given object as checked in the list
            </summary>
            <param name="modelObject">The model object to be checked</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CheckObjects(System.Collections.IEnumerable)">
            <summary>
            Mark the given objects as checked in the list
            </summary>
            <param name="modelObjects">The model object to be checked</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CheckSubItem(System.Object,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Put a check into the check box at the given cell
            </summary>
            <param name="rowObject"></param>
            <param name="column"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CheckIndeterminateSubItem(System.Object,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Put an indeterminate check into the check box at the given cell
            </summary>
            <param name="rowObject"></param>
            <param name="column"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.IsChecked(System.Object)">
            <summary>
            Return true of the given object is checked
            </summary>
            <param name="modelObject">The model object whose checkedness is returned</param>
            <returns>Is the given object checked?</returns>
            <remarks>If the given object is not in the list, this method returns false.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.IsCheckedIndeterminate(System.Object)">
            <summary>
            Return true of the given object is indeterminately checked
            </summary>
            <param name="modelObject">The model object whose checkedness is returned</param>
            <returns>Is the given object indeterminately checked?</returns>
            <remarks>If the given object is not in the list, this method returns false.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.IsSubItemChecked(System.Object,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Is there a check at the check box at the given cell
            </summary>
            <param name="rowObject"></param>
            <param name="column"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetCheckState(System.Object)">
            <summary>
            Get the checkedness of an object from the model. Returning null means the
            model does not know and the value from the control will be used.
            </summary>
            <param name="modelObject"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.PutCheckState(System.Object,System.Windows.Forms.CheckState)">
            <summary>
            Record the change of checkstate for the given object in the model.
            This does not update the UI -- only the model
            </summary>
            <param name="modelObject"></param>
            <param name="state"></param>
            <returns>The check state that was recorded and that should be used to update
            the control.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetObjectCheckedness(System.Object,System.Windows.Forms.CheckState)">
            <summary>
            Change the check state of the given object to be the given state.
            </summary>
            <remarks>
            If the given model object isn't in the list, we still try to remember
            its state, in case it is referenced in the future.</remarks>
            <param name="modelObject"></param>
            <param name="state"></param>
            <returns>True if the checkedness of the model changed</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ToggleCheckObject(System.Object)">
            <summary>
            Toggle the checkedness of the given object. A checked object becomes
            unchecked; an unchecked or indeterminate object becomes checked.
            If the list has tristate checkboxes, the order is:
               unchecked -> checked -> indeterminate -> unchecked ...
            </summary>
            <param name="modelObject">The model object to be checked</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ToggleSubItemCheckBox(System.Object,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Toggle the check at the check box of the given cell
            </summary>
            <param name="rowObject"></param>
            <param name="column"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UncheckObject(System.Object)">
            <summary>
            Mark the given object as unchecked in the list
            </summary>
            <param name="modelObject">The model object to be unchecked</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UncheckObjects(System.Collections.IEnumerable)">
            <summary>
            Mark the given objects as unchecked in the list
            </summary>
            <param name="modelObjects">The model object to be checked</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UncheckSubItem(System.Object,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Uncheck the check at the given cell
            </summary>
            <param name="rowObject"></param>
            <param name="column"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetColumn(System.Int32)">
            <summary>
            Return the column at the given index
            </summary>
            <param name="index">Index of the column to be returned</param>
            <returns>An OLVColumn</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetColumn(System.String)">
            <summary>
            Return the column at the given title.
            </summary>
            <param name="name">Name of the column to be returned</param>
            <returns>An OLVColumn</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetFilteredColumns(System.Windows.Forms.View)">
            <summary>
            Return a collection of columns that are visible to the given view.
            Only Tile and Details have columns; all other views have 0 columns.
            </summary>
            <param name="view">Which view are the columns being calculate for?</param>
            <returns>A list of columns</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetItemCount">
            <summary>
            Return the number of items in the list
            </summary>
            <returns>the number of items in the list</returns>
            <remarks>If a filter is installed, this will return the number of items that match the filter.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetItem(System.Int32)">
            <summary>
            Return the item at the given index
            </summary>
            <param name="index">Index of the item to be returned</param>
            <returns>An OLVListItem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetModelObject(System.Int32)">
            <summary>
            Return the model object at the given index
            </summary>
            <param name="index">Index of the model object to be returned</param>
            <returns>A model object</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetItemAt(System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn@)">
            <summary>
            Find the item and column that are under the given co-ords
            </summary>
            <param name="x">X co-ord</param>
            <param name="y">Y co-ord</param>
            <param name="hitColumn">The column under the given point</param>
            <returns>The item under the given point. Can be null.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetSubItem(System.Int32,System.Int32)">
            <summary>
            Return the sub item at the given index/column
            </summary>
            <param name="index">Index of the item to be returned</param>
            <param name="columnIndex">Index of the subitem to be returned</param>
            <returns>An OLVListSubItem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EnsureGroupVisible(System.Windows.Forms.ListViewGroup)">
            <summary>
            Scroll the listview so that the given group is at the top.
            </summary>
            <param name="lvg">The group to be revealed</param>
            <remarks><para>
            If the group is already visible, the list will still be scrolled to move
            the group to the top, if that is possible.
            </para>
            <para>This only works when the list is showing groups (obviously).</para>
            <para>This does not work on virtual lists, since virtual lists don't use ListViewGroups
            for grouping. Use <see cref="M:BrightIdeasSoftware.VirtualObjectListView.EnsureNthGroupVisible(System.Int32)"/> instead.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EnsureModelVisible(System.Object)">
            <summary>
            Ensure that the given model object is visible
            </summary>
            <param name="modelObject">The model object to be revealed</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetSelectedObject">
            <summary>
            Return the model object of the row that is selected or null if there is no selection or more than one selection
            </summary>
            <returns>Model object or null</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetSelectedObjects">
            <summary>
            Return the model objects of the rows that are selected or an empty collection if there is no selection
            </summary>
            <returns>ArrayList</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetCheckedObject">
            <summary>
            Return the model object of the row that is checked or null if no row is checked
            or more than one row is checked
            </summary>
            <returns>Model object or null</returns>
            <remarks>Use CheckedObject property instead of this method</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetCheckedObjects">
            <summary>
            Get the collection of model objects that are checked.
            </summary>
            <remarks>Use CheckedObjects property instead of this method</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.IndexOf(System.Object)">
            <summary>
            Find the given model object within the listview and return its index
            </summary>
            <param name="modelObject">The model object to be found</param>
            <returns>The index of the object. -1 means the object was not present</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RefreshItem(BrightIdeasSoftware.OLVListItem)">
            <summary>
            Rebuild the given ListViewItem with the data from its associated model.
            </summary>
            <remarks>This method does not resort or regroup the view. It simply updates
            the displayed data of the given item</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RefreshObject(System.Object)">
            <summary>
            Rebuild the data on the row that is showing the given object.
            </summary>
            <remarks>
            <para>
            This method does not resort or regroup the view.
            </para>
            <para>
            The given object is *not* used as the source of data for the rebuild.
            It is only used to locate the matching model in the <see cref="P:BrightIdeasSoftware.ObjectListView.Objects"/> collection,
            then that matching model is used as the data source. This distinction is
            only important in model classes that have overridden the Equals() method.
            </para>
            <para>
            If you want the given model object to replace the pre-existing model,
            use <see cref="M:BrightIdeasSoftware.ObjectListView.UpdateObject(System.Object)"/>. 
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RefreshObjects(System.Collections.IList)">
            <summary>
            Update the rows that are showing the given objects
            </summary>
            <remarks>
            <para>This method does not resort or regroup the view.</para>
            <para>This method can safely be called from background threads.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RefreshSelectedObjects">
            <summary>
            Update the rows that are selected
            </summary>
            <remarks>This method does not resort or regroup the view.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SelectObject(System.Object)">
            <summary>
            Select the row that is displaying the given model object, in addition to any current selection.
            </summary>
            <param name="modelObject">The object to be selected</param>
            <remarks>Use the <see cref="P:BrightIdeasSoftware.ObjectListView.SelectedObject"/> property to deselect all other rows</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SelectObject(System.Object,System.Boolean)">
            <summary>
            Select the row that is displaying the given model object, in addition to any current selection.
            </summary>
            <param name="modelObject">The object to be selected</param>
            <param name="setFocus">Should the object be focused as well?</param>
            <remarks>Use the <see cref="P:BrightIdeasSoftware.ObjectListView.SelectedObject"/> property to deselect all other rows</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SelectObjects(System.Collections.IList)">
            <summary>
            Select the rows that is displaying any of the given model object. All other rows are deselected.
            </summary>
            <param name="modelObjects">A collection of model objects</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Freeze">
            <summary>
            Freeze the listview so that it no longer updates itself.
            </summary>
            <remarks>Freeze()/Unfreeze() calls nest correctly</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Unfreeze">
            <summary>
            Unfreeze the listview. If this call is the outermost Unfreeze(),
            the contents of the listview will be rebuilt.
            </summary>
            <remarks>Freeze()/Unfreeze() calls nest correctly</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.DoUnfreeze">
            <summary>
            Do the actual work required when the listview is unfrozen
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SuspendSelectionEvents">
            <summary>
            Suspend selection events until a matching ResumeSelectionEvents()
            is called.
            </summary>
            <remarks>Calls to this method nest correctly. Every call to SuspendSelectionEvents()
            must have a matching ResumeSelectionEvents().</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ResumeSelectionEvents">
            <summary>
            Resume raising selection events.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SuspendSelectionEventsDuring">
            <summary>
            Returns a disposable that will disable selection events
            during a using() block.
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Sort">
            <summary>
            Sort the items by the last sort column and order
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Sort(System.String)">
            <summary>
            Sort the items in the list view by the values in the given column and the last sort order
            </summary>
            <param name="columnToSortName">The name of the column whose values will be used for the sorting</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Sort(System.Int32)">
            <summary>
            Sort the items in the list view by the values in the given column and the last sort order
            </summary>
            <param name="columnToSortIndex">The index of the column whose values will be used for the sorting</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Sort(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Sort the items in the list view by the values in the given column and the last sort order
            </summary>
            <param name="columnToSort">The column whose values will be used for the sorting</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Sort(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Sort the items in the list view by the values in the given column and by the given order.
            </summary>
            <param name="columnToSort">The column whose values will be used for the sorting.
            If null, the first column will be used.</param>
            <param name="order">The ordering to be used for sorting. If this is None,
            this.Sorting and then SortOrder.Ascending will be used</param>
            <remarks>If ShowGroups is true, the rows will be grouped by the given column.
            If AlwaysGroupsByColumn is not null, the rows will be grouped by that column,
            and the rows within each group will be sorted by the given column.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ShowSortIndicator">
            <summary>
            Put a sort indicator next to the text of the sort column
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ShowSortIndicator(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Put a sort indicator next to the text of the given given column
            </summary>
            <param name="columnToSort">The column to be marked</param>
            <param name="sortOrder">The sort order in effect on that column</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeSortIndicatorImages">
            <summary>
            If the sort indicator images don't already exist, this method will make and install them
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Unsort">
            <summary>
            Remove any sorting and revert to the given order of the model objects
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CreateGroups(System.Collections.Generic.IEnumerable{BrightIdeasSoftware.OLVGroup})">
            <summary>
            Do the actual work of creating the given list of groups
            </summary>
            <param name="groups"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CorrectSubItemColors(System.Windows.Forms.ListViewItem)">
            <summary>
            For some reason, UseItemStyleForSubItems doesn't work for the colors
            when owner drawing the list, so we have to specifically give each subitem
            the desired colors
            </summary>
            <param name="olvi">The item whose subitems are to be corrected</param>
            <remarks>Cells drawn via BaseRenderer don't need this, but it is needed
            when an owner drawn cell uses DrawDefault=true</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.FillInValues(BrightIdeasSoftware.OLVListItem,System.Object)">
            <summary>
            Fill in the given OLVListItem with values of the given row
            </summary>
            <param name="lvi">the OLVListItem that is to be stuff with values</param>
            <param name="rowObject">the model object from which values will be taken</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ForceSubItemImagesExStyle">
            <summary>
            Make sure the ListView has the extended style that says to display subitem images.
            </summary>
            <remarks>This method must be called after any .NET call that update the extended styles
            since they seem to erase this setting.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetActualImageIndex(System.Object)">
            <summary>
            Convert the given image selector to an index into our image list.
            Return -1 if that's not possible
            </summary>
            <param name="imageSelector"></param>
            <returns>Index of the image in the imageList, or -1</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetHeaderToolTip(System.Int32)">
            <summary>
            Return the tooltip that should be shown when the mouse is hovered over the given column
            </summary>
            <param name="columnIndex">The column index whose tool tip is to be fetched</param>
            <returns>A string or null if no tool tip is to be shown</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetCellToolTip(System.Int32,System.Int32)">
            <summary>
            Return the tooltip that should be shown when the mouse is hovered over the given cell
            </summary>
            <param name="columnIndex">The column index whose tool tip is to be fetched</param>
            <param name="rowIndex">The row index whose tool tip is to be fetched</param>
            <returns>A string or null if no tool tip is to be shown</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ModelToItem(System.Object)">
            <summary>
            Return the OLVListItem that displays the given model object
            </summary>
            <param name="modelObject">The modelObject whose item is to be found</param>
            <returns>The OLVListItem that displays the model, or null</returns>
            <remarks>This method has O(n) performance.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.PostProcessRows">
            <summary>
            Do the work required after the items in a listview have been created
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.PostProcessOneRow(System.Int32,System.Int32,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Do the work required after one item in a listview have been created
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.PrepareAlternateBackColors">
             <summary>
             Prepare the listview to show alternate row backcolors
             </summary>
             <remarks>We cannot rely on lvi.Index in this method.
             In a straight list, lvi.Index is the display index, and can be used to determine
             whether the row should be colored. But when organised by groups, lvi.Index is not
             useable because it still refers to the position in the overall list, not the display order.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetAllSubItemImages">
            <summary>
            Setup all subitem images on all rows
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetSubItemImages(System.Int32,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Tell the underlying list control which images to show against the subitems
            </summary>
            <param name="rowIndex">the index at which the item occurs</param>
            <param name="item">the item whose subitems are to be set</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetSubItemImages(System.Int32,BrightIdeasSoftware.OLVListItem,System.Boolean)">
            <summary>
            Tell the underlying list control which images to show against the subitems
            </summary>
            <param name="rowIndex">the index at which the item occurs</param>
            <param name="item">the item whose subitems are to be set</param>
            <param name="shouldClearImages">will existing images be cleared if no new image is provided?</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetSubItemImage(System.Int32,System.Int32,BrightIdeasSoftware.OLVListSubItem,System.Boolean)">
            <summary>
            Set the subitem image natively
            </summary>
            <param name="rowIndex"></param>
            <param name="subItemIndex"></param>
            <param name="subItem"></param>
            <param name="shouldClearImages"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.TakeOwnershipOfObjects">
            <summary>
            Take ownership of the 'objects' collection. This separats our collection from the source.
            </summary>
            <remarks>
            <para>
            This method
            separates the 'objects' instance variable from its source, so that any AddObject/RemoveObject
            calls will modify our collection and not the original colleciton.
            </para>
            <para>
            This method has the intentional side-effect of converting our list of objects to an ArrayList.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.TriggerFormatRowEvent(System.Int32,System.Int32,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Trigger FormatRow and possibly FormatCell events for the given item
            </summary>
            <param name="rowIndex"></param>
            <param name="displayIndex"></param>
            <param name="olvi"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.Reset">
            <summary>
            Make the list forget everything -- all rows and all columns
            </summary>
            <remarks>Use <see cref="M:BrightIdeasSoftware.ObjectListView.ClearObjects"/> if you want to remove just the rows.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetupBaseImageList">
            <summary>
            Update our externally visible image list so it holds the same images as our shadow list, but sized correctly
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeResizedImageList(System.Int32,System.Int32,System.Windows.Forms.ImageList)">
            <summary>
            Return a copy of the given source image list, where each image has been resized to be height x height in size.
            If source is null, an empty image list of the given size is returned
            </summary>
            <param name="width">Height and width of the new images</param>
            <param name="height">Height and width of the new images</param>
            <param name="source">Source of the images (can be null)</param>
            <returns>A new image list</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeResizedImage(System.Int32,System.Int32,System.Drawing.Image,System.Drawing.Color)">
            <summary>
            Return a bitmap of the given height x height, which shows the given image, centred.
            </summary>
            <param name="width">Height and width of new bitmap</param>
            <param name="height">Height and width of new bitmap</param>
            <param name="image">Image to be centred</param>
            <param name="transparent">The background color</param>
            <returns>A new bitmap</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.InitializeStateImageList">
            <summary>
            Initialize the state image list with the required checkbox images
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetupSubItemCheckBoxes">
            <summary>
            Setup this control so it can display check boxes on subitems
            (or primary checkboxes in virtual mode)
            </summary>
            <remarks>This gives the ListView a small image list, if it doesn't already have one.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.InitializeSubItemCheckBoxImages">
            <summary>
            Make sure the small image list for this control has checkbox images 
            (used for sub-item checkboxes).
            </summary>
            <remarks>
            <para>
            This gives the ListView a small image list, if it doesn't already have one.
            </para>
            <para>
            ObjectListView has to manage checkboxes on subitems separate from the checkboxes on each row.
            The underlying ListView knows about the per-row checkboxes, and to make them work, OLV has to 
            correctly configure the StateImageList. However, the ListView cannot do checkboxes in subitems,
            so ObjectListView has to handle them in a differnt fashion. So, per-row checkboxes are controlled
            by images in the StateImageList, but per-cell checkboxes are handled by images in the SmallImageList.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnDrawColumnHeader(System.Windows.Forms.DrawListViewColumnHeaderEventArgs)">
            <summary>
            Owner draw the column header
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnDrawItem(System.Windows.Forms.DrawListViewItemEventArgs)">
            <summary>
            Owner draw the item
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnDrawSubItem(System.Windows.Forms.DrawListViewSubItemEventArgs)">
            <summary>
            Owner draw a single subitem
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnMouseDown(System.Windows.Forms.MouseEventArgs)">
            <summary>
            We need the click count in the mouse up event, but that is always 1.
            So we have to remember the click count from the preceding mouse down event.
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnMouseLeave(System.EventArgs)">
            <summary>
            When the mouse leaves the control, remove any hot item highlighting
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnMouseMove(System.Windows.Forms.MouseEventArgs)">
            <summary>
            When the mouse moves, we might need to change the hot item.
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnMouseUp(System.Windows.Forms.MouseEventArgs)">
            <summary>
            Check to see if we need to start editing a cell
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ProcessHyperlinkClicked(BrightIdeasSoftware.CellClickEventArgs)">
            <summary>
            Tell the world that a hyperlink was clicked and if the event isn't handled,
            do the default processing.
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.StandardHyperlinkClickedProcessing(BrightIdeasSoftware.HyperlinkClickedEventArgs)">
            <summary>
            Do the default processing for a hyperlink clicked event, which
            is to try and open the url.
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnRightMouseUp(System.Windows.Forms.MouseEventArgs)">
            <summary>
            The user right clicked on the control
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnSelectedIndexChanged(System.EventArgs)">
            <summary>
            This method is called every time a row is selected or deselected. This can be
            a pain if the user shift-clicks 100 rows. We override this method so we can
            trigger one event for any number of select/deselects that come from one user action
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnHandleCreated(System.EventArgs)">
            <summary>
            Called when the handle of the underlying control is created
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnControlCreated">
            <summary>
            This method is called after the control has been fully created.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ShouldStartCellEdit(System.Windows.Forms.MouseEventArgs)">
            <summary>
            Should we start editing the cell in response to the given mouse button event?
            </summary>
            <param name="e"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ProcessDialogKey(System.Windows.Forms.Keys)">
            <summary>
            Handle a key press on this control. We specifically look for F2 which edits the primary column,
            or a Tab character during an edit operation, which tries to start editing on the next (or previous) cell.
            </summary>
            <param name="keyData"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EditModel(System.Object)">
            <summary>
            Start an editing operation on the first editable column of the given model.
            </summary>
            <param name="rowModel"></param>
            <remarks>
            <para>
            If the model doesn't exist, or there are no editable columns, this method
            will do nothing.</para>
            <para>
            This will start an edit operation regardless of CellActivationMode.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.EditSubItem(BrightIdeasSoftware.OLVListItem,System.Int32)">
            <summary>
            Begin an edit operation on the given cell.
            </summary>
            <remarks>This performs various sanity checks and passes off the real work to StartCellEdit().</remarks>
            <param name="item">The row to be edited</param>
            <param name="subItemIndex">The index of the cell to be edited</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.StartCellEdit(BrightIdeasSoftware.OLVListItem,System.Int32)">
            <summary>
            Really start an edit operation on a given cell. The parameters are assumed to be sane.
            </summary>
            <param name="item">The row to be edited</param>
            <param name="subItemIndex">The index of the cell to be edited</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CalculateCellEditorBounds(BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            Calculate the bounds of the edit control for the given item/column
            </summary>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CalculateCellEditorBoundsOwnerDrawn(BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Rectangle,System.Drawing.Size)">
            <summary>
            Calculate the bounds of the edit control for the given item/column, when the listview
            is being owner drawn.
            </summary>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="r"></param>
            <param name="preferredSize"> </param>
            <returns>A rectangle that is the bounds of the cell editor</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CalculateCellEditorBoundsStandard(BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Rectangle,System.Drawing.Size)">
            <summary>
            Calculate the bounds of the edit control for the given item/column, when the listview
            is not being owner drawn.
            </summary>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="cellBounds"></param>
            <param name="preferredSize"> </param>
            <returns>A rectangle that is the bounds of the cell editor</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetControlValue(System.Windows.Forms.Control,System.Object,System.String)">
            <summary>
            Try to give the given value to the provided control. Fall back to assigning a string
            if the value assignment fails.
            </summary>
            <param name="control">A control</param>
            <param name="value">The value to be given to the control</param>
            <param name="stringValue">The string to be given if the value doesn't work</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ConfigureControl">
            <summary>
            Setup the given control to be a cell editor
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetControlValue(System.Windows.Forms.Control)">
            <summary>
            Return the value that the given control is showing
            </summary>
            <param name="control"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CellEditor_Validating(System.Object,System.ComponentModel.CancelEventArgs)">
            <summary>
            Called when the cell editor could be about to lose focus. Time to commit the change
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CalculateCellBounds(BrightIdeasSoftware.OLVListItem,System.Int32)">
            <summary>
            Return the bounds of the given cell
            </summary>
            <param name="item">The row to be edited</param>
            <param name="subItemIndex">The index of the cell to be edited</param>
            <returns>A Rectangle</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CalculateCellTextBounds(BrightIdeasSoftware.OLVListItem,System.Int32)">
            <summary>
            Return the bounds of the given cell only until the edge of the current text
            </summary>
            <param name="item">The row to be edited</param>
            <param name="subItemIndex">The index of the cell to be edited</param>
            <returns>A Rectangle</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetCellEditor(BrightIdeasSoftware.OLVListItem,System.Int32)">
            <summary>
            Return a control that can be used to edit the value of the given cell.
            </summary>
            <param name="item">The row to be edited</param>
            <param name="subItemIndex">The index of the cell to be edited</param>
            <returns>A Control to edit the given cell</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetFirstNonNullValue(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Get the first non-null value of the given column.
            At most 1000 rows will be considered.
            </summary>
            <param name="column"></param>
            <returns>The first non-null value, or null if no non-null values were found</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.MakeDefaultCellEditor(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Return a TextBox that can be used as a default cell editor.
            </summary>
            <param name="column">What column does the cell belong to?</param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ConfigureAutoComplete(System.Windows.Forms.TextBox,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Configure the given text box to autocomplete unique values
            from the given column. At most 1000 rows will be considered.
            </summary>
            <param name="tb">The textbox to configure</param>
            <param name="column">The column used to calculate values</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ConfigureAutoComplete(System.Windows.Forms.TextBox,BrightIdeasSoftware.OLVColumn,System.Int32)">
            <summary>
            Configure the given text box to autocomplete unique values
            from the given column. At most 1000 rows will be considered.
            </summary>
            <param name="tb">The textbox to configure</param>
            <param name="column">The column used to calculate values</param>
            <param name="maxRows">Consider only this many rows</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CancelCellEdit">
            <summary>
            Stop editing a cell and throw away any changes.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.PossibleFinishCellEditing">
            <summary>
            If a cell edit is in progress, finish the edit.
            </summary>
            <returns>Returns false if the finishing process was cancelled
            (i.e. the cell editor is still on screen)</returns>
            <remarks>This method does not guarantee that the editing will finish. The validation
            process can cause the finishing to be aborted. Developers should check the return value
            or use IsCellEditing property after calling this method to see if the user is still
            editing a cell.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.PossibleFinishCellEditing(System.Boolean)">
            <summary>
            If a cell edit is in progress, finish the edit.
            </summary>
            <returns>Returns false if the finishing process was cancelled
            (i.e. the cell editor is still on screen)</returns>
            <remarks>This method does not guarantee that the editing will finish. The validation
            process can cause the finishing to be aborted. Developers should check the return value
            or use IsCellEditing property after calling this method to see if the user is still
            editing a cell.</remarks>
            <param name="expectingCellEdit">True if it is likely that another cell is going to be 
            edited immediately after this cell finishes editing</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.FinishCellEdit">
            <summary>
            Finish the cell edit operation, writing changed data back to the model object
            </summary>
            <remarks>This method does not trigger a Validating event, so it always finishes
            the cell edit.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.FinishCellEdit(System.Boolean)">
            <summary>
            Finish the cell edit operation, writing changed data back to the model object
            </summary>
            <remarks>This method does not trigger a Validating event, so it always finishes
            the cell edit.</remarks>
            <param name="expectingCellEdit">True if it is likely that another cell is going to be 
            edited immediately after this cell finishes editing</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CleanupCellEdit(System.Boolean,System.Boolean)">
            <summary>
            Remove all trace of any existing cell edit operation
            </summary>
            <param name="expectingCellEdit">True if it is likely that another cell is going to be 
            edited immediately after this cell finishes editing</param>
            <param name="disposeOfCellEditor">True if the cell editor should be disposed </param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ClearHotItem">
            <summary>
            Force the hot item to be recalculated
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RefreshHotItem">
            <summary>
            Force the hot item to be recalculated
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateHotItem(System.Drawing.Point)">
            <summary>
            The mouse has moved to the given pt. See if the hot item needs to be updated
            </summary>
            <param name="pt">Where is the mouse?</param>
            <remarks>This is the main entry point for hot item handling</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateHotItem(BrightIdeasSoftware.OlvListViewHitTestInfo)">
            <summary>
            The mouse has moved to the given pt. See if the hot item needs to be updated
            </summary>
            <param name="hti"></param>
            <remarks>This is the main entry point for hot item handling</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateHotRow(BrightIdeasSoftware.OLVListItem)">
            <summary>
            Update the given row using the current hot item information
            </summary>
            <param name="olvi"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateHotRow(System.Int32,System.Int32,BrightIdeasSoftware.HitTestLocation,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Update the given row using the given hot item information
            </summary>
            <param name="rowIndex"></param>
            <param name="columnIndex"></param>
            <param name="hitLocation"></param>
            <param name="olvi"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ApplyRowStyle(BrightIdeasSoftware.OLVListItem,BrightIdeasSoftware.IItemStyle,System.Boolean)">
            <summary>
            Apply a style to the given row
            </summary>
            <param name="olvi"></param>
            <param name="style"></param>
            <param name="primaryColumnOnly"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ApplyCellStyle(BrightIdeasSoftware.OLVListItem,System.Int32,BrightIdeasSoftware.IItemStyle)">
            <summary>
            Apply a style to a cell
            </summary>
            <param name="olvi"></param>
            <param name="columnIndex"></param>
            <param name="style"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UnapplyHotItem(System.Int32)">
            <summary>
            Remove hot item styling from the given row
            </summary>
            <param name="index"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnItemDrag(System.Windows.Forms.ItemDragEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnDragEnter(System.Windows.Forms.DragEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnDragOver(System.Windows.Forms.DragEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnDragDrop(System.Windows.Forms.DragEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnDragLeave(System.EventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnGiveFeedback(System.Windows.Forms.GiveFeedbackEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.OnQueryContinueDrag(System.Windows.Forms.QueryContinueDragEventArgs)">
            <summary>
            
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.AddDecoration(BrightIdeasSoftware.IDecoration)">
            <summary>
            Add the given decoration to those on this list and make it appear
            </summary>
            <param name="decoration">The decoration</param>
            <remarks>
            A decoration scrolls with the listview. An overlay stays fixed in place.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.AddOverlay(BrightIdeasSoftware.IOverlay)">
            <summary>
            Add the given overlay to those on this list and make it appear
            </summary>
            <param name="overlay">The overlay</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.DrawAllDecorations(System.Drawing.Graphics,System.Collections.Generic.List{BrightIdeasSoftware.OLVListItem})">
            <summary>
            Draw all the decorations
            </summary>
            <param name="g">A Graphics</param>
            <param name="itemsThatWereRedrawn">The items that were redrawn and whose decorations should also be redrawn</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HasDecoration(BrightIdeasSoftware.IDecoration)">
            <summary>
            Is the given decoration shown on this list
            </summary>
            <param name="decoration">The overlay</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HasOverlay(BrightIdeasSoftware.IOverlay)">
            <summary>
            Is the given overlay shown on this list?
            </summary>
            <param name="overlay">The overlay</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.HideOverlays">
            <summary>
            Hide any overlays.
            </summary>
            <remarks>
            This is only a temporary hiding -- the overlays will be shown
            the next time the ObjectListView redraws.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.InitializeEmptyListMsgOverlay">
            <summary>
            Create and configure the empty list msg overlay
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.InitializeStandardOverlays">
            <summary>
            Initialize the standard image and text overlays
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ShowOverlays">
            <summary>
            Make sure that any overlays are visible.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RefreshOverlays">
            <summary>
            Refresh the display of the overlays
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RefreshOverlay(BrightIdeasSoftware.IOverlay)">
            <summary>
            Refresh the display of just one overlays
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RemoveDecoration(BrightIdeasSoftware.IDecoration)">
            <summary>
            Remove the given decoration from this list
            </summary>
            <param name="decoration">The decoration to remove</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.RemoveOverlay(BrightIdeasSoftware.IOverlay)">
            <summary>
            Remove the given overlay to those on this list
            </summary>
            <param name="overlay">The overlay</param>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.CreateColumnFilter">
            <summary>
            Create a filter that will enact all the filtering currently installed
            on the visible columns.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.FilterObjects(System.Collections.IEnumerable,BrightIdeasSoftware.IModelFilter,BrightIdeasSoftware.IListFilter)">
            <summary>
            Do the actual work of filtering
            </summary>
            <param name="originalObjects"></param>
            <param name="aModelFilter"></param>
            <param name="aListFilter"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ResetColumnFiltering">
            <summary>
            Remove all column filtering.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateColumnFiltering">
            <summary>
            Update the filtering of this ObjectListView based on the value filtering
            defined in each column
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.UpdateFiltering">
            <summary>
            When some setting related to filtering changes, this method is called.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.GetPersistentCheckState(System.Object)">
            <summary>
            Gets the checkedness of the given model.
            </summary>
            <param name="model">The model</param>
            <returns>The checkedness of the model. Defaults to unchecked.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.SetPersistentCheckState(System.Object,System.Windows.Forms.CheckState)">
            <summary>
            Remember the check state of the given model object
            </summary>
            <param name="model">The model to be remembered</param>
            <param name="state">The model's checkedness</param>
            <returns>The state given to the method</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ObjectListView.ClearPersistentCheckState">
            <summary>
            Forget any persistent checkbox state
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.AfterSearching">
            <summary>
            Triggered after a ObjectListView has been searched by the user typing into the list
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.AfterSorting">
            <summary>
            Triggered after a ObjectListView has been sorted
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.BeforeSearching">
            <summary>
            Triggered before a ObjectListView is searched by the user typing into the list
            </summary>
            <remarks>
            Set Cancelled to true to prevent the searching from taking place.
            Changing StringToFind or StartSearchFrom will change the subsequent search.
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.BeforeSorting">
            <summary>
            Triggered before a ObjectListView is sorted
            </summary>
            <remarks>
            Set Cancelled to true to prevent the sort from taking place.
            Changing ColumnToSort or SortOrder will change the subsequent sort.
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.AfterCreatingGroups">
            <summary>
            Triggered after a ObjectListView has created groups
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.BeforeCreatingGroups">
            <summary>
            Triggered before a ObjectListView begins to create groups
            </summary>
            <remarks>
            Set Groups to prevent the default group creation process
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.AboutToCreateGroups">
            <summary>
            Triggered just before a ObjectListView creates groups
            </summary>
            <remarks>
            You can make changes to the groups, which have been created, before those
            groups are created within the listview.
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.CanDrop">
            <summary>
            This event is triggered when the user moves a drag over an ObjectListView that
            has a SimpleDropSink installed as the drop handler.
            </summary>
            <remarks>
            Handlers for this event should set the Effect argument and optionally the
            InfoMsg property. They can also change any of the DropTarget* setttings to change
            the target of the drop.
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.CellEditFinishing">
            <summary>
            Triggered when a cell is about to finish being edited.
            </summary>
            <remarks>If Cancel is already true, the user is cancelling the edit operation.
            Set Cancel to true to prevent the value from the cell being written into the model.
            You cannot prevent the editing from finishing within this event -- you need
            the CellEditValidating event for that.</remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.CellEditStarting">
            <summary>
            Triggered when a cell is about to be edited.
            </summary>
            <remarks>Set Cancel to true to prevent the cell being edited.
            You can change the the Control to be something completely different.</remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.CellEditValidating">
            <summary>
            Triggered when a cell editor needs to be validated
            </summary>
            <remarks>
            If this event is cancelled, focus will remain on the cell editor.
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.CellClick">
            <summary>
            Triggered when a cell is left clicked.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.CellOver">
            <summary>
            Triggered when the mouse is above a cell.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.CellRightClick">
            <summary>
            Triggered when a cell is right clicked.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.CellToolTipShowing">
            <summary>
            This event is triggered when a cell needs a tool tip.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.SubItemChecking">
            <summary>
            This event is triggered when a checkbox is checked/unchecked on a subitem
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.ColumnRightClick">
            <summary>
            Triggered when a column header is right clicked.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.Dropped">
            <summary>
            This event is triggered when the user releases a drag over an ObjectListView that
            has a SimpleDropSink installed as the drop handler.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.Filter">
            <summary>
            This event is triggered when the control needs to filter its collection of objects.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.FormatCell">
            <summary>
            This event is triggered when a cell needs to be formatted.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.Freezing">
            <summary>
            This event is triggered when the frozeness of the control changes.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.FormatRow">
            <summary>
            This event is triggered when a row needs to be formatted.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.GroupExpandingCollapsing">
            <summary>
            This event is triggered when a group is about to collapse or expand.
            This can be cancelled to prevent the expansion.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.GroupStateChanged">
            <summary>
            This event is triggered when a group changes state.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.HeaderToolTipShowing">
            <summary>
            This event is triggered when a header needs a tool tip.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.HotItemChanged">
            <summary>
            Triggered when the "hot" item changes
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.HyperlinkClicked">
            <summary>
            Triggered when a hyperlink cell is clicked.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.GroupTaskClicked">
            <summary>
            Triggered when the task text of a group is clicked.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.IsHyperlink">
            <summary>
            Is the value in the given cell a hyperlink.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.ItemsAdding">
            <summary>
            Some new objects are about to be added to an ObjectListView.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.ItemsChanged">
            <summary>
            The contents of the ObjectListView has changed.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.ItemsChanging">
            <summary>
            The contents of the ObjectListView is about to change via a SetObjects call
            </summary>
            <remarks>
            <para>Set Cancelled to true to prevent the contents of the list changing. This does not work with virtual lists.</para>
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.ItemsRemoving">
            <summary>
            Some objects are about to be removed from an ObjectListView.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.ModelCanDrop">
            <summary>
            This event is triggered when the user moves a drag over an ObjectListView that
            has a SimpleDropSink installed as the drop handler, and when the source control
            for the drag was an ObjectListView.
            </summary>
            <remarks>
            Handlers for this event should set the Effect argument and optionally the
            InfoMsg property. They can also change any of the DropTarget* setttings to change
            the target of the drop.
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.ModelDropped">
            <summary>
            This event is triggered when the user releases a drag over an ObjectListView that
            has a SimpleDropSink installed as the drop handler and when the source control
            for the drag was an ObjectListView.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.SelectionChanged">
            <summary>
            This event is triggered once per user action that changes the selection state
            of one or more rows.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ObjectListView.Scroll">
            <summary>
            This event is triggered when the contents of the ObjectListView has scrolled.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IsVistaOrLater">
            <summary>
            Gets whether the program running on Vista or later?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IsWin7OrLater">
            <summary>
            Gets whether the program running on Win7 or later?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SmoothingMode">
            <summary>
            Gets or sets how what smoothing mode will be applied to graphic operations.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.TextRenderingHint">
            <summary>
            Gets or sets how should text be renderered.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.GroupTitleDefault">
            <summary>
            Gets or sets the string that will be used to title groups when the group key is null.
            Exposed so it can be localized.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IgnoreMissingAspects">
            <summary>
            Gets or sets whether all ObjectListViews will silently ignore missing aspect errors.
            </summary>
            <remarks>
            <para>
            By default, if an ObjectListView is asked to display an aspect
            (i.e. a field/property/method)
            that does not exist from a model, it displays an error message in that cell, since that 
            condition is normally a programming error. There are some use cases where
            this is not an error -- in those cases, set this to true and ObjectListView will
            simply display an empty cell.
            </para>
            <para>Be warned: if you set this to true, it can be very difficult to track down
            typing mistakes or name changes in AspectNames.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ShowCellPaddingBounds">
            <summary>
            Gets or sets whether the control will draw a rectangle in each cell showing the cell padding.
            </summary>
            <remarks>
            <para>
            This can help with debugging display problems from cell padding.
            </para>
            <para>As with all cell padding, this setting only takes effect when the control is owner drawn.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.DefaultDisabledItemStyle">
            <summary>
            Gets the style that will be used by default to format disabled rows
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.AdditionalFilter">
            <summary>
            Gets or sets an model filter that is combined with any column filtering that the end-user specifies.
            </summary>
            <remarks>This is different from the ModelFilter property, since setting that will replace
            any column filtering, whereas setting this will combine this filter with the column filtering</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.AllColumns">
            <summary>
            Get or set all the columns that this control knows about.
            Only those columns where IsVisible is true will be seen by the user.
            </summary>
            <remarks>
            <para>
            If you want to add new columns programmatically, add them to
            AllColumns and then call RebuildColumns(). Normally, you do not have to
            deal with this property directly. Just use the IDE.
            </para>
            <para>If you do add or remove columns from the AllColumns collection,
            you have to call RebuildColumns() to make those changes take effect.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.AlternateRowBackColor">
            <summary>
            Gets or sets the background color of every second row 
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.AlternateRowBackColorOrDefault">
            <summary>
            Gets the alternate row background color that has been set, or the default color
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.AlwaysGroupByColumn">
            <summary>
            This property forces the ObjectListView to always group items by the given column.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.AlwaysGroupBySortOrder">
            <summary>
            If AlwaysGroupByColumn is not null, this property will be used to decide how
            those groups are sorted. If this property has the value SortOrder.None, then
            the sort order will toggle according to the users last header click.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.BaseSmallImageList">
            <summary>
            Give access to the image list that is actually being used by the control
            </summary>
            <remarks>
            Normally, it is preferable to use SmallImageList. Only use this property
            if you know exactly what you are doing.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellEditActivation">
            <summary>
            How does the user indicate that they want to edit a cell?
            None means that the listview cannot be edited.
            </summary>
            <remarks>Columns can also be marked as editable.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellEditKeyEngine">
            <summary>
            Gets or sets the engine that will handle key presses during a cell edit operation.
            Settings this to null will reset it to default value.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellEditor">
            <summary>
            Gets the control that is currently being used for editing a cell.
            </summary>
            <remarks>This will obviously be null if no cell is being edited.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellEditTabChangesRows">
            <summary>
            Gets or sets the behaviour of the Tab key when editing a cell on the left or right
            edge of the control. If this is false (the default), pressing Tab will wrap to the other side
            of the same row. If this is true, pressing Tab when editing the right most cell will advance 
            to the next row 
            and Shift-Tab when editing the left-most cell will change to the previous row.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellEditEnterChangesRows">
            <summary>
            Gets or sets the behaviour of the Enter keys while editing a cell.
            If this is false (the default), pressing Enter will simply finish the editing operation.
            If this is true, Enter will finish the edit operation and start a new edit operation
            on the cell below the current cell, wrapping to the top of the next row when at the bottom cell.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellToolTip">
            <summary>
            Gets the tool tip control that shows tips for the cells
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellPadding">
            <summary>
            Gets or sets how many pixels will be left blank around each cell of this item.
            Cell contents are aligned after padding has been taken into account.
            </summary>
            <remarks>
            <para>Each value of the given rectangle will be treated as an inset from
            the corresponding side. The width of the rectangle is the padding for the
            right cell edge. The height of the rectangle is the padding for the bottom
            cell edge.
            </para>
            <para>
            So, this.olv1.CellPadding = new Rectangle(1, 2, 3, 4); will leave one pixel
            of space to the left of the cell, 2 pixels at the top, 3 pixels of space
            on the right edge, and 4 pixels of space at the bottom of each cell.
            </para>
            <para>
            This setting only takes effect when the control is owner drawn.
            </para>
            <para>This setting only affects the contents of the cell. The background is
            not affected.</para>
            <para>If you set this to a foolish value, your control will appear to be empty.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellVerticalAlignment">
            <summary>
            Gets or sets how cells will be vertically aligned by default.
            </summary>
            <remarks>This setting only takes effect when the control is owner drawn. It will only be noticable
            when RowHeight has been set such that there is some vertical space in each row.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CheckBoxes">
            <summary>
            Should this list show checkboxes?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CheckedObject">
            <summary>
            Return the model object of the row that is checked or null if no row is checked
            or more than one row is checked
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CheckedObjects">
            <summary>
            Get or set the collection of model objects that are checked.
            When setting this property, any row whose model object isn't
            in the given collection will be unchecked. Setting to null is
            equivilent to unchecking all.
            </summary>
            <remarks>
            <para>
            This property returns a simple collection. Changes made to the returned
            collection do NOT affect the list. This is different to the behaviour of
            CheckedIndicies collection.
            </para>
            <para>
            .NET's CheckedItems property is not helpful. It is just a short-hand for
            iterating through the list looking for items that are checked.
            </para>
            <para>
            The performance of the get method is O(n), where n is the number of items
            in the control. The performance of the set method is
            O(n + m) where m is the number of objects being checked. Be careful on long lists.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CheckedObjectsEnumerable">
            <summary>
            Gets or sets the checked objects from an enumerable.
            </summary>
            <remarks>
            Useful for checking all objects in the list.
            </remarks>
            <example>
            this.olv1.CheckedObjectsEnumerable = this.olv1.Objects;
            </example>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.Columns">
            <summary>
            Gets Columns for this list. We hide the original so we can associate
            a specialised editor with it.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ColumnsForTileView">
            <summary>
            Get/set the list of columns that should be used when the list switches to tile view.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ColumnsInDisplayOrder">
            <summary>
            Return the visible columns in the order they are displayed to the user
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ContentRectangle">
            <summary>
            Get the area of the control that shows the list, minus any header control
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CopySelectionOnControlC">
            <summary>
            Gets or sets if the selected rows should be copied to the clipboard when the user presses Ctrl-C
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CopySelectionOnControlCUsesDragSource">
            <summary>
            Gets or sets whether the Control-C copy to clipboard functionality should use
            the installed DragSource to create the data object that is placed onto the clipboard.
            </summary>
            <remarks>This is normally what is desired, unless a custom DragSource is installed 
            that does some very specialized drag-drop behaviour.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.Decorations">
            <summary>
            Gets the list of decorations that will be drawn the ListView
            </summary>
            <remarks>
            <para>
            Do not modify the contents of this list directly. Use the AddDecoration() and RemoveDecoration() methods.
            </para>
            <para>
            A decoration scrolls with the list contents. An overlay is fixed in place.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.DefaultRenderer">
            <summary>
            When owner drawing, this renderer will draw columns that do not have specific renderer
            given to them
            </summary>
            <remarks>If you try to set this to null, it will revert to a BaseRenderer</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.DisabledItemStyle">
            <summary>
            Gets or sets the style that will be applied to disabled items.
            </summary>
            <remarks>If this is not set explicitly, <see cref="P:BrightIdeasSoftware.ObjectListView.DefaultDisabledItemStyle"/>  will be used.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.DisabledObjects">
            <summary>
            Gets or sets the list of model objects that are disabled.
            Disabled objects cannot be selected or activated.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.DragSource">
            <summary>
            Gets or sets the object that controls how drags start from this control
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.DropSink">
            <summary>
            Gets or sets the object that controls how drops are accepted and processed
            by this ListView.
            </summary>
            <remarks>
            <para>
            If the given sink is an instance of SimpleDropSink, then events from the drop sink
            will be automatically forwarded to the ObjectListView (which means that handlers
            for those event can be configured within the IDE).
            </para>
            <para>If this is set to null, the control will not accept drops.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.EmptyListMsg">
            <summary>
            Gets or sets the text that should be shown when there are no items in this list view.
            </summary>
            <remarks>If the EmptyListMsgOverlay has been changed to something other than a TextOverlay,
            this property does nothing</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.EmptyListMsgFont">
            <summary>
            Gets or sets the font in which the List Empty message should be drawn
            </summary>
            <remarks>If the EmptyListMsgOverlay has been changed to something other than a TextOverlay,
            this property does nothing</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.EmptyListMsgFontOrDefault">
            <summary>
            Return the font for the 'list empty' message or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.EmptyListMsgOverlay">
            <summary>
            Gets or sets the overlay responsible for drawing the List Empty msg.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.FilteredObjects">
            <summary>
            Gets the collection of objects that survive any filtering that may be in place.
            </summary>
            <remarks>
            <para>
            This collection is the result of filtering the current list of objects. 
            It is not a snapshot of the filtered list that was last used to build the control. 
            </para>
            <para>
            Normal warnings apply when using this with virtual lists. It will work, but it
            may take a while.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.FilterMenuBuildStrategy">
            <summary>
            Gets or sets the strategy object that will be used to build the Filter menu
            </summary>
            <remarks>If this is null, no filter menu will be built.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.Groups">
            <summary>
            Hide the Groups collection so it's not visible in the Properties grid.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.GroupImageList">
            <summary>
            Gets or sets the image list from which group header will take their images
            </summary>
            <remarks>If this is not set, then group headers will not show any images.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.GroupWithItemCountFormat">
            <summary>
            Gets how the group label should be formatted when a group is empty or
            contains more than one item
            </summary>
            <remarks>
            The given format string must have two placeholders:
            <list type="bullet">
            <item><description>{0} - the original group title</description></item>
            <item><description>{1} - the number of items in the group</description></item>
            </list>
            </remarks>
            <example>"{0} [{1} items]"</example>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.GroupWithItemCountFormatOrDefault">
            <summary>
            Return this.GroupWithItemCountFormat or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.GroupWithItemCountSingularFormat">
            <summary>
            Gets how the group label should be formatted when a group contains only a single item
            </summary>
            <remarks>
            The given format string must have two placeholders:
            <list type="bullet">
            <item><description>{0} - the original group title</description></item>
            <item><description>{1} - the number of items in the group (always 1)</description></item>
            </list>
            </remarks>
            <example>"{0} [{1} item]"</example>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.GroupWithItemCountSingularFormatOrDefault">
            <summary>
            Gets GroupWithItemCountSingularFormat or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HasCollapsibleGroups">
            <summary>
            Gets or sets whether or not the groups in this ObjectListView should be collapsible.
            </summary>
            <remarks>
            This feature only works under Vista and later.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HasEmptyListMsg">
            <summary>
            Does this listview have a message that should be drawn when the list is empty?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HasOverlays">
            <summary>
            Get whether there are any overlays to be drawn
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HeaderControl">
            <summary>
            Gets the header control for the ListView
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HeaderFont">
            <summary>
            Gets or sets the font in which the text of the column headers will be drawn
            </summary>
            <remarks>Individual columns can override this through their HeaderFormatStyle property.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HeaderFormatStyle">
            <summary>
            Gets or sets the style that will be used to draw the columm headers of the listview
            </summary>
            <remarks>
            <para>
            This is only used when HeaderUsesThemes is false.
            </para>
            <para>
            Individual columns can override this through their HeaderFormatStyle property.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HeaderMaximumHeight">
            <summary>
            Gets or sets the maximum height of the header. -1 means no maximum.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HeaderUsesThemes">
            <summary>
            Gets or sets whether the header will be drawn strictly according to the OS's theme. 
            </summary>
            <remarks>
            <para>
            If this is set to true, the header will be rendered completely by the system, without
            any of ObjectListViews fancy processing -- no images in header, no filter indicators,
            no word wrapping, no header styling.
            </para>
            <para>If this is set to false, ObjectListView will render the header as it thinks best.
            If no special features are required, then ObjectListView will delegate rendering to the OS.
            Otherwise, ObjectListView will draw the header according to the configuration settings.
            </para>
            <para>
            The effect of not being themed will be different from OS to OS. At
            very least, the sort indicator will not be standard. 
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HeaderWordWrap">
            <summary>
            Gets or sets the whether the text in the header will be word wrapped.
            </summary>
            <remarks>
            <para>Line breaks will be applied between words. Words that are too long
            will still be ellipsed.</para>
            <para>
            As with all settings that make the header look different, HeaderUsesThemes must be set to false, otherwise
            the OS will be responsible for drawing the header, and it does not allow word wrapped text.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HeaderToolTip">
            <summary>
            Gets the tool tip that shows tips for the column headers
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HotRowIndex">
            <summary>
            Gets the index of the row that the mouse is currently over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HotColumnIndex">
            <summary>
            Gets the index of the subitem that the mouse is currently over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HotCellHitLocation">
            <summary>
            Gets the part of the item/subitem that the mouse is currently over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HotCellHitLocationEx">
            <summary>
            Gets an extended indication of the part of item/subitem/group that the mouse is currently over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HotGroup">
            <summary>
            Gets the group that the mouse is over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HotItemIndex">
            <summary>
            The index of the item that is 'hot', i.e. under the cursor. -1 means no item.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HotItemStyle">
            <summary>
            What sort of formatting should be applied to the row under the cursor?
            </summary>
            <remarks>This only takes effect when UseHotItem is true.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HyperlinkStyle">
            <summary>
            What sort of formatting should be applied to hyperlinks?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HighlightBackgroundColor">
            <summary>
            What color should be used for the background of selected rows?
            </summary>
            <remarks>Windows does not give the option of changing the selection background.
            So the control has to be owner drawn to see the result of this setting.
            Setting UseCustomSelectionColors = true will do this for you.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HighlightBackgroundColorOrDefault">
            <summary>
            Return the color should be used for the background of selected rows or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HighlightForegroundColor">
            <summary>
            What color should be used for the foreground of selected rows?
            </summary>
            <remarks>Windows does not give the option of changing the selection foreground (text color).
            So the control has to be owner drawn to see the result of this setting.
            Setting UseCustomSelectionColors = true will do this for you.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HighlightForegroundColorOrDefault">
            <summary>
            Return the color should be used for the foreground of selected rows or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IncludeHiddenColumnsInDataTransfer">
            <summary>
            Gets or sets whether or not hidden columns should be included in the text representation
            of rows that are copied or dragged to another application. If this is false (the default),
            only visible columns will be included.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IncludeColumnHeadersInCopy">
            <summary>
            Gets or sets whether or not hidden columns should be included in the text representation
            of rows that are copied or dragged to another application. If this is false (the default),
            only visible columns will be included.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IsCellEditing">
            <summary>
            Return true if a cell edit operation is currently happening
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IsDesignMode">
            <summary>
            Return true if the ObjectListView is being used within the development environment.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IsFiltering">
            <summary>
            Gets whether or not the current list is filtering its contents
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IsSearchOnSortColumn">
            <summary>
            When the user types into a list, should the values in the current sort column be searched to find a match?
            If this is false, the primary column will always be used regardless of the sort column.
            </summary>
            <remarks>When this is true, the behavior is like that of ITunes.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IsSimpleDropSink">
            <summary>
            Gets or sets if this control will use a SimpleDropSink to receive drops
            </summary>
            <remarks>
            <para>
            Setting this replaces any previous DropSink.
            </para>
            <para>
            After setting this to true, the SimpleDropSink will still need to be configured
            to say when it can accept drops and what should happen when something is dropped.
            The need to do these things makes this property mostly useless :(
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.IsSimpleDragSource">
            <summary>
            Gets or sets if this control will use a SimpleDragSource to initiate drags
            </summary>
            <remarks>Setting this replaces any previous DragSource</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.Items">
            <summary>
            Hide the Items collection so it's not visible in the Properties grid.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ItemRenderer">
            <summary>
            This renderer draws the items when in the list is in non-details view.
            In details view, the renderers for the individuals columns are responsible.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.LastSortColumn">
            <summary>
            Which column did we last sort by
            </summary>
            <remarks>This is an alias for PrimarySortColumn</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.LastSortOrder">
            <summary>
            Which direction did we last sort
            </summary>
            <remarks>This is an alias for PrimarySortOrder</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ListFilter">
            <summary>
            Gets or  sets the filter that is applied to our whole list of objects.
            </summary>
            <remarks>
            The list is updated immediately to reflect this filter. 
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ModelFilter">
            <summary>
            Gets or  sets the filter that is applied to each model objects in the list
            </summary>
            <remarks>
            <para>You may want to consider using <see cref="P:BrightIdeasSoftware.ObjectListView.AdditionalFilter"/> instead of this property,
            since AdditionalFilter combines with column filtering at runtime. Setting this property simply
            replaces any column filter the user may have given.</para>
            <para>
            The list is updated immediately to reflect this filter. 
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MouseMoveHitTest">
            <summary>
            Gets the hit test info last time the mouse was moved.
            </summary>
            <remarks>Useful for hot item processing.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.OLVGroups">
            <summary>
            Gets or sets the list of groups shown by the listview.
            </summary>
            <remarks>
            This property does not work like the .NET Groups property. It should
            be treated as a read-only property.
            Changes made to the list are NOT reflected in the ListView itself -- it is pointless to add
            or remove groups to/from this list. Such modifications will do nothing.
            To do such things, you must listen for
            BeforeCreatingGroups or AboutToCreateGroups events, and change the list of
            groups in those events.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CollapsedGroups">
            <summary>
            Gets or sets the collection of OLVGroups that are collapsed.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.OwnerDrawnHeader">
            <summary>
            Gets or sets whether the user wants to owner draw the header control
            themselves. If this is false (the default), ObjectListView will use
            custom drawing to render the header, if needed.
            </summary>
            <remarks>
            If you listen for the DrawColumnHeader event, you need to set this to true,
            otherwise your event handler will not be called.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.Objects">
            <summary>
            Get/set the collection of objects that this list will show
            </summary>
            <remarks>
            <para>
            The contents of the control will be updated immediately after setting this property.
            </para>
            <para>This method preserves selection, if possible. Use <see cref="M:BrightIdeasSoftware.ObjectListView.SetObjects(System.Collections.IEnumerable,System.Boolean)"/> if
            you do not want to preserve the selection. Preserving selection is the slowest part of this
            code and performance is O(n) where n is the number of selected rows.</para>
            <para>This method is not thread safe.</para>
            <para>The property DOES work on virtual lists: setting is problem-free, but if you try to get it
            and the list has 10 million objects, it may take some time to return.</para>
            <para>This collection is unfiltered. Use <see cref="P:BrightIdeasSoftware.ObjectListView.FilteredObjects"/> to access just those objects
            that survive any installed filters.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ObjectsForClustering">
            <summary>
            Gets the collection of objects that will be considered when creating clusters
            (which are used to generate Excel-like column filters)
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.OverlayImage">
            <summary>
            Gets or sets the image that will be drawn over the top of the ListView
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.OverlayText">
            <summary>
            Gets or sets the text that will be drawn over the top of the ListView
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.OverlayTransparency">
            <summary>
            Gets or sets the transparency of all the overlays.
            0 is completely transparent, 255 is completely opaque.
            </summary>
            <remarks>
            This is obsolete. Use Transparency on each overlay.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.Overlays">
            <summary>
            Gets the list of overlays that will be drawn on top of the ListView
            </summary>
            <remarks>
            You can add new overlays and remove overlays that you have added, but
            don't mess with the overlays that you didn't create.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.PersistentCheckBoxes">
            <summary>
            Gets or sets whether or not primary checkboxes will persistent their values across list rebuild
            and filtering operations.
            </summary>
            <remarks>
            <para>
            If you use CheckStateGetter/Putter, the checkedness of a row will already be persisted
            by those methods. This property is only useful when you don't explicitly set CheckStateGetter/Putter.
            </para>
            <para>This defaults to true for virtual lists (Fast, Tree). If you set it to false on virtual lists,
            you have to install CheckStateGetter/Putters.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CheckStateMap">
            <summary>
            Gets or sets a dictionary that remembers the check state of model objects
            </summary>
            <remarks>This is used when PersistentCheckBoxes is true and for virtual lists.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.PrimarySortColumn">
            <summary>
            Which column did we last sort by
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.PrimarySortOrder">
            <summary>
            Which direction did we last sort
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.RenderNonEditableCheckboxesAsDisabled">
            <summary>
            Gets or sets if non-editable checkboxes are drawn as disabled. Default is false.
            </summary>
            <remarks>
            <para>This only has effect in owner drawn mode.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.RowHeight">
            <summary>
            Specify the height of each row in the control in pixels.
            </summary>
            <remarks><para>The row height in a listview is normally determined by the font size and the small image list size.
            This setting allows that calculation to be overridden (within reason: you still cannot set the line height to be
            less than the line height of the font used in the control). </para>
            <para>Setting it to -1 means use the normal calculation method.</para>
            <para><bold>This feature is experiemental!</bold> Strange things may happen to your program,
            your spouse or your pet if you use it.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.RowHeightEffective">
            <summary>
            How many pixels high is each row?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.RowsPerPage">
            <summary>
            How many rows appear on each page of this control
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SecondarySortColumn">
            <summary>
            Get/set the column that will be used to resolve comparisons that are equal when sorting.
            </summary>
            <remarks>There is no user interface for this setting. It must be set programmatically.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SecondarySortOrder">
            <summary>
            When the SecondarySortColumn is used, in what order will it compare results?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectAllOnControlA">
            <summary>
            Gets or sets if all rows should be selected when the user presses Ctrl-A
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectColumnsOnRightClick">
            <summary>
            When the user right clicks on the column headers, should a menu be presented which will allow
            them to choose which columns will be shown in the view?
            </summary>
            <remarks>This is just a compatibility wrapper for the SelectColumnsOnRightClickBehaviour
            property.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectColumnsOnRightClickBehaviour">
            <summary>
            Gets or sets how the user will be able to select columns when the header is right clicked
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectColumnsMenuStaysOpen">
            <summary>
            When the column select menu is open, should it stay open after an item is selected?
            Staying open allows the user to turn more than one column on or off at a time.
            </summary>
            <remarks>This only works when SelectColumnsOnRightClickBehaviour is set to InlineMenu.
            It has no effect when the behaviour is set to SubMenu.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectedColumn">
            <summary>
            Gets or sets the column that is drawn with a slight tint.
            </summary>
            <remarks>
            <para>
            If TintSortColumn is true, the sort column will automatically
            be made the selected column.
            </para>
            <para>
            The colour of the tint is controlled by SelectedColumnTint.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectedRowDecoration">
            <summary>
            Gets or sets the decoration that will be drawn on all selected rows
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectedColumnTint">
            <summary>
            What color should be used to tint the selected column?
            </summary>
            <remarks>
            The tint color must be alpha-blendable, so if the given color is solid
            (i.e. alpha = 255), it will be changed to have a reasonable alpha value.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectedIndex">
            <summary>
            Gets or sets the index of the row that is currently selected. 
            When getting the index, if no row is selected,or more than one is selected, return -1.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectedItem">
            <summary>
            Gets or sets the ListViewItem that is currently selected . If no row is selected, or more than one is selected, return null.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectedObject">
            <summary>
            Gets the model object from the currently selected row, if there is only one row selected. 
            If no row is selected, or more than one is selected, returns null.
            When setting, this will select the row that is displaying the given model object and focus on it. 
            All other rows are deselected.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectedObjects">
            <summary>
            Get the model objects from the currently selected rows. If no row is selected, the returned List will be empty.
            When setting this value, select the rows that is displaying the given model objects. All other rows are deselected.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ShowCommandMenuOnRightClick">
            <summary>
            When the user right clicks on the column headers, should a menu be presented which will allow
            them to choose common tasks to perform on the listview?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ShowFilterMenuOnRightClick">
            <summary>
            Gets or sets whether this ObjectListView will show Excel like filtering
            menus when the header control is right clicked
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ShowGroups">
            <summary>
            Should this list show its items in groups?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ShowSortIndicators">
            <summary>
            Should the list view show a bitmap in the column header to show the sort direction?
            </summary>
            <remarks>
            The only reason for not wanting to have sort indicators is that, on pre-XP versions of
            Windows, having sort indicators required the ListView to have a small image list, and
            as soon as you give a ListView a SmallImageList, the text of column 0 is bumped 16
            pixels to the right, even if you never used an image.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ShowImagesOnSubItems">
            <summary>
            Should the list view show images on subitems?
            </summary>
            <remarks>
            <para>Virtual lists have to be owner drawn in order to show images on subitems</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ShowItemCountOnGroups">
            <summary>
            This property controls whether group labels will be suffixed with a count of items.
            </summary>
            <remarks>
            The format of the suffix is controlled by GroupWithItemCountFormat/GroupWithItemCountSingularFormat properties
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.ShowHeaderInAllViews">
            <summary>
            Gets or sets whether the control will show column headers in all
            views (true), or only in Details view (false)
            </summary>
            <remarks>
            <para>
            This property is not working correctly. JPP 2010/04/06.
            It works fine if it is set before the control is created.
            But if it turned off once the control is created, the control
            loses its checkboxes (weird!)
            </para>
            <para>
            To changed this setting after the control is created, things
            are complicated. If it is off and we want it on, we have
            to change the View and the header will appear. If it is currently
            on and we want to turn it off, we have to both change the view
            AND recreate the handle. Recreating the handle is a problem 
            since it makes our checkbox style disappear. 
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SmallImageList">
            <summary>
            Override the SmallImageList property so we can correctly shadow its operations.
            </summary>
            <remarks><para>If you use the RowHeight property to specify the row height, the SmallImageList
            must be fully initialised before setting/changing the RowHeight. If you add new images to the image
            list after setting the RowHeight, you must assign the imagelist to the control again. Something as simple
            as this will work:
            <code>listView1.SmallImageList = listView1.SmallImageList;</code></para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SmallImageSize">
            <summary>
            Return the size of the images in the small image list or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SortGroupItemsByPrimaryColumn">
            <summary>
            When the listview is grouped, should the items be sorted by the primary column?
            If this is false, the items will be sorted by the same column as they are grouped.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SpaceBetweenGroups">
            <summary>
            When the listview is grouped, how many pixels should exist between the end of one group and the
            beginning of the next?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.TintSortColumn">
            <summary>
            Should the sort column show a slight tinge?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.TriStateCheckBoxes">
            <summary>
            Should each row have a tri-state checkbox?
            </summary>
            <remarks>
            If this is true, the user can choose the third state (normally Indeterminate). Otherwise, user clicks
            alternate between checked and unchecked. CheckStateGetter can still return Indeterminate when this
            setting is false.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.TopItemIndex">
            <summary>
            Get or set the index of the top item of this listview
            </summary>
            <remarks>
            <para>
            This property only works when the listview is in Details view and not showing groups.
            </para>
            <para>
            The reason that it does not work when showing groups is that, when groups are enabled,
            the Windows msg LVM_GETTOPINDEX always returns 0, regardless of the
            scroll position.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UpdateSpaceFillingColumnsWhenDraggingColumnDivider">
            <summary>
            When resizing a column by dragging its divider, should any space filling columns be
            resized at each mouse move? If this is false, the filling columns will be
            updated when the mouse is released.
            </summary>
            <remarks>
            <para>
            If you have a space filling column
            is in the left of the column that is being resized, this will look odd: 
            the right edge of the column will be dragged, but
            its <b>left</b> edge will move since the space filling column is shrinking.
            </para>
            <para>This is logical behaviour -- it just looks wrong.   
            </para>
            <para>
            Given the above behavior is probably best to turn this property off if your space filling
            columns aren't the right-most columns.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UnfocusedHighlightBackgroundColor">
            <summary>
            What color should be used for the background of selected rows when the control doesn't have the focus?
            </summary>
            <remarks>Windows does not give the option of changing the selection background.
            So the control has to be owner drawn to see the result of this setting.
            Setting UseCustomSelectionColors = true will do this for you.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UnfocusedHighlightBackgroundColorOrDefault">
            <summary>
            Return the color should be used for the background of selected rows when the control doesn't have the focus or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UnfocusedHighlightForegroundColor">
            <summary>
            What color should be used for the foreground of selected rows when the control doesn't have the focus?
            </summary>
            <remarks>Windows does not give the option of changing the selection foreground (text color).
            So the control has to be owner drawn to see the result of this setting.
            Setting UseCustomSelectionColors = true will do this for you.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UnfocusedHighlightForegroundColorOrDefault">
            <summary>
            Return the color should be used for the foreground of selected rows when the control doesn't have the focus or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseAlternatingBackColors">
            <summary>
            Should the list give a different background color to every second row?
            </summary>
            <remarks><para>The color of the alternate rows is given by AlternateRowBackColor.</para>
            <para>There is a "feature" in .NET for listviews in non-full-row-select mode, where
            selected rows are not drawn with their correct background color.</para></remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseCellFormatEvents">
            <summary>
            Should FormatCell events be called for each cell in the control?
            </summary>
            <remarks>
            <para>In many situations, no cell level formatting is performed. ObjectListView
            can run somewhat faster if it does not trigger a format cell event for every cell
            unless it is required. So, by default, it does not raise an event for each cell.
            </para>
            <para>ObjectListView *does* raise a FormatRow event every time a row is rebuilt.
            Individual rows can decide whether to raise FormatCell
            events for every cell in row.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseCustomSelectionColors">
            <summary>
            Should the selected row be drawn with non-standard foreground and background colors?
            </summary>
            <remarks>
            When this is enabled, the control becomes owner drawn.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseExplorerTheme">
            <summary>
            Gets or sets whether this ObjectListView will use the same hot item and selection 
            mechanism that Vista Explorer does.
            </summary>
            <remarks>This property has many imperfections:
            <list type="bullet">
            <item><description>This only works on Vista and later</description></item>
            <item><description>It does nothing for owner drawn lists.
            Owner drawn lists are (naturally) controlled by their renderers.</description></item>
            <item><description>It does not work well with AlternateRowBackColors.</description></item>
            <item><description>It does not play well with HotItemStyles.</description></item>
            <item><description>It looks a little bit silly is FullRowSelect is false.</description></item>
            </list>
            But if you absolutely have to look like Vista, this is your property. 
            Do not complain if settings this messes up other things.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseFiltering">
            <summary>
            Gets or sets whether the list should enable filtering
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseFilterIndicator">
            <summary>
            Gets or sets whether the list should put an indicator into a column's header to show that
            it is filtering on that column
            </summary>
            <remarks>If you set this to true, HeaderUsesThemes is automatically set to false, since
            we can only draw a filter indicator when not using a themed header.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseHotItem">
            <summary>
            Should the item under the cursor be formatted in a special way?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseHyperlinks">
            <summary>
            Gets or sets whether this listview should show hyperlinks in the cells.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseOverlays">
            <summary>
            Should this control show overlays
            </summary>
            <remarks>Overlays are enabled by default and would only need to be disabled
            if they were causing problems in your development environment.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseSubItemCheckBoxes">
            <summary>
            Should this control be configured to show check boxes on subitems?
            </summary>
            <remarks>If this is set to True, the control will be given a SmallImageList if it
            doesn't already have one. Also, if it is a virtual list, it will be set to owner
            drawn, since virtual lists can't draw check boxes without being owner drawn.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseTranslucentSelection">
            <summary>
            Gets or sets if the ObjectListView will use a translucent selection mechanism like Vista.
            </summary>
            <remarks>
            <para>
            Unlike UseExplorerTheme, this Vista-like scheme works on XP and for both
            owner and non-owner drawn lists.
            </para>
            <para>
            This will replace any SelectedRowDecoration that has been installed.
            </para>
            <para>
            If you don't like the colours used for the selection, ignore this property and 
            just create your own RowBorderDecoration and assigned it to SelectedRowDecoration,
            just like this property setter does.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseTranslucentHotItem">
            <summary>
            Gets or sets if the ObjectListView will use a translucent hot row highlighting mechanism like Vista.
            </summary>
            <remarks>
            <para>
            Setting this will replace any HotItemStyle that has been installed.
            </para>
            <para>
            If you don't like the colours used for the hot item, ignore this property and 
            just create your own HotItemStyle, fill in the values you want, and assigned it to HotItemStyle property,
            just like this property setter does.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.View">
            <summary>
            Get/set the style of view that this listview is using
            </summary>
            <remarks>Switching to tile or details view installs the columns appropriate to that view.
            Confusingly, in tile view, every column is shown as a row of information.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.BooleanCheckStateGetter">
            <summary>
            This delegate fetches the checkedness of an object as a boolean only.
            </summary>
            <remarks>Use this if you never want to worry about the
            Indeterminate state (which is fairly common).
            <para>
            This is a convenience wrapper around the CheckStateGetter property.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.BooleanCheckStatePutter">
            <summary>
            This delegate sets the checkedness of an object as a boolean only. It must return
            true or false indicating if the object was checked or not.
            </summary>
            <remarks>Use this if you never want to worry about the
            Indeterminate state (which is fairly common).
            <para>
            This is a convenience wrapper around the CheckStatePutter property.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CanShowGroups">
            <summary>
            Gets whether or not this listview is capabale of showing groups
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CanUseApplicationIdle">
            <summary>
            Gets or sets whether ObjectListView can rely on Application.Idle events
            being raised.
            </summary>
            <remarks>In some host environments (e.g. when running as an extension within
            VisualStudio and possibly Office), Application.Idle events are never raised.
            Set this to false when Idle events will not be raised, and ObjectListView will
            raise those events itself.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CellToolTipGetter">
            <summary>
            This delegate is called when the list wants to show a tooltip for a particular cell.
            The delegate should return the text to display, or null to use the default behavior
            (which is to show the full text of truncated cell values).
            </summary>
            <remarks>
            Displaying the full text of truncated cell values only work for FullRowSelect listviews.
            This is MS's behavior, not mine. Don't complain to me :)
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CheckedAspectName">
            <summary>
            The name of the property (or field) that holds whether or not a model is checked.
            </summary>
            <remarks>
            <para>The property be modifiable. It must have a return type of bool (or of bool? if
            TriStateCheckBoxes is true).</para>
            <para>Setting this property replaces any CheckStateGetter or CheckStatePutter that have been installed.
            Conversely, later setting the CheckStateGetter or CheckStatePutter properties will take precedence
            over the behavior of this property.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CheckStateGetter">
            <summary>
            This delegate will be called whenever the ObjectListView needs to know the check state
            of the row associated with a given model object.
            </summary>
            <remarks>
            <para>.NET has no support for indeterminate values, but as of v2.0, this class allows
            indeterminate values.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CheckStatePutter">
            <summary>
            This delegate will be called whenever the user tries to change the check state of a row.
            The delegate should return the state that was actually set, which may be different
            to the state given.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.CustomSorter">
            <summary>
            This delegate can be used to sort the table in a custom fasion.
            </summary>
            <remarks>
            <para>
            The delegate must install a ListViewItemSorter on the ObjectListView.
            Installing the ItemSorter does the actual work of sorting the ListViewItems.
            See ColumnComparer in the code for an example of what an ItemSorter has to do.
            </para>
            <para>
            Do not install a CustomSorter on a VirtualObjectListView. Override the SortObjects()
            method of the IVirtualListDataSource instead.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.HeaderToolTipGetter">
            <summary>
            This delegate is called when the list wants to show a tooltip for a particular header.
            The delegate should return the text to display, or null to use the default behavior
            (which is to not show any tooltip).
            </summary>
            <remarks>
            Installing a HeaderToolTipGetter takes precedence over any text in OLVColumn.ToolTipText.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.RowFormatter">
            <summary>
            This delegate can be used to format a OLVListItem before it is added to the control.
            </summary>
            <remarks>
            <para>The model object for the row can be found through the RowObject property of the OLVListItem object.</para>
            <para>All subitems normally have the same style as list item, so setting the forecolor on one
            subitem changes the forecolor of all subitems.
            To allow subitems to have different attributes, do this:
            <code>myListViewItem.UseItemStyleForSubItems = false;</code>.
            </para>
            <para>If UseAlternatingBackColors is true, the backcolor of the listitem will be calculated
            by the control and cannot be controlled by the RowFormatter delegate.
            In general, trying to use a RowFormatter
            when UseAlternatingBackColors is true does not work well.</para>
            <para>As it says in the summary, this is called <b>before</b> the item is added to the control.
            Many properties of the OLVListItem itself are not available at that point, including:
            Index, Selected, Focused, Bounds, Checked, DisplayIndex.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.LowLevelScrollPosition">
            <summary>
            Return a point that represents the current horizontal and vertical scroll positions 
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.UseNotifyPropertyChanged">
            <summary>
            Gets or sets whether or not ObjectListView should subscribe to INotifyPropertyChanged
            events on the model objects that it is given.
            </summary>
            <remarks>
            <para>
            This should be set before calling SetObjects(). If you set this to false,
            ObjectListView will unsubscribe to all current model objects.
            </para>
            <para>If you set this to true on a virtual list, the ObjectListView will 
            walk all the objects in the list trying to subscribe to change notifications.
            If you have 10,000,000 items in your virtual list, this may take some time.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelSortAscending">
            <summary>
            Gets or set the text to be used for the sorting ascending command
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelSortDescending">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelGroupBy">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelLockGroupingOn">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelUnlockGroupingOn">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelTurnOffGroups">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelUnsort">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelColumns">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.MenuLabelSelectColumns">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.Frozen">
            <summary>
            Get or set whether or not the listview is frozen. When the listview is
            frozen, it will not update itself.
            </summary>
            <remarks><para>The Frozen property is similar to the methods Freeze()/Unfreeze()
            except that setting Frozen property to false immediately unfreezes the control
            regardless of the number of Freeze() calls outstanding.</para></remarks>
            <example>objectListView1.Frozen = false; // unfreeze the control now!
            </example>
        </member>
        <member name="P:BrightIdeasSoftware.ObjectListView.SelectionEventsSuspended">
            <summary>
            Returns true if selection events are currently suspended.
            While selection events are suspended, neither SelectedIndexChanged
            or SelectionChanged events will be raised.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ObjectListView.CellEditActivateMode">
            <summary>
            How does a user indicate that they want to edit cells?
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.CellEditActivateMode.None">
            <summary>
            This list cannot be edited. F2 does nothing.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.CellEditActivateMode.SingleClick">
            <summary>
            A single click on  a <strong>subitem</strong> will edit the value. Single clicking the primary column,
            selects the row just like normal. The user must press F2 to edit the primary column.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.CellEditActivateMode.DoubleClick">
            <summary>
            Double clicking a subitem or the primary column will edit that cell.
            F2 will edit the primary column.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.CellEditActivateMode.F2Only">
            <summary>
            Pressing F2 is the only way to edit the cells. Once the primary column is being edited,
            the other cells in the row can be edited by pressing Tab.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ObjectListView.ColumnSelectBehaviour">
            <summary>
            These values specify how column selection will be presented to the user
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.ColumnSelectBehaviour.None">
            <summary>
            No column selection will be presented 
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.ColumnSelectBehaviour.InlineMenu">
            <summary>
            The columns will be show in the main menu
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.ColumnSelectBehaviour.Submenu">
            <summary>
            The columns will be shown in a submenu
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ObjectListView.ColumnSelectBehaviour.ModelDialog">
            <summary>
            A model dialog will be presented to allow the user to choose columns
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ObjectListView.ObjectListViewState">
            <summary>
            Instances of this class are used to store the state of an ObjectListView.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ObjectListView.SuspendSelectionDisposable">
            <summary>
            Implementation only class that suspends and resumes selection
            events on instance creation and disposal.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.#ctor">
            <summary>
            Create a VirtualObjectListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.GetItemCount">
            <summary>
            Return the number of items in the list
            </summary>
            <returns>the number of items in the list</returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.GetModelObject(System.Int32)">
            <summary>
            Return the model object at the given index
            </summary>
            <param name="index">Index of the model object to be returned</param>
            <returns>A model object</returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.IndexOf(System.Object)">
            <summary>
            Find the given model object within the listview and return its index
            </summary>
            <param name="modelObject">The model object to be found</param>
            <returns>The index of the object. -1 means the object was not present</returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.ModelToItem(System.Object)">
            <summary>
            Return the OLVListItem that displays the given model object
            </summary>
            <param name="modelObject">The modelObject whose item is to be found</param>
            <returns>The OLVListItem that displays the model, or null</returns>
            <remarks>This method has O(n) performance.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.AddObjects(System.Collections.ICollection)">
            <summary>
            Add the given collection of model objects to this control.
            </summary>
            <param name="modelObjects">A collection of model objects</param>
            <remarks>
            <para>The added objects will appear in their correct sort position, if sorting
            is active. Otherwise, they will appear at the end of the list.</para>
            <para>No check is performed to see if any of the objects are already in the ListView.</para>
            <para>Null objects are silently ignored.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.ClearObjects">
            <summary>
            Remove all items from this list
            </summary>
            <remark>This method can safely be called from background threads.</remark>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.EnsureNthGroupVisible(System.Int32)">
            <summary>
            Scroll the listview so that the given group is at the top.
            </summary>
            <param name="groupIndex">The index of the group to be revealed</param>
            <remarks><para>
            If the group is already visible, the list will still be scrolled to move
            the group to the top, if that is possible.
            </para>
            <para>This only works when the list is showing groups (obviously).</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.RefreshObjects(System.Collections.IList)">
            <summary>
            Update the rows that are showing the given objects
            </summary>
            <remarks>This method does not resort the items.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.RefreshSelectedObjects">
            <summary>
            Update the rows that are selected
            </summary>
            <remarks>This method does not resort or regroup the view.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.RemoveObjects(System.Collections.ICollection)">
            <summary>
            Remove all of the given objects from the control
            </summary>
            <param name="modelObjects">Collection of objects to be removed</param>
            <remarks>
            <para>Nulls and model objects that are not in the ListView are silently ignored.</para>
            <para>Due to problems in the underlying ListView, if you remove all the objects from
            the control using this method and the list scroll vertically when you do so,
            then when you subsequenially add more objects to the control,
            the vertical scroll bar will become confused and the control will draw one or more
            blank lines at the top of the list. </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.SelectObject(System.Object,System.Boolean)">
            <summary>
            Select the row that is displaying the given model object. All other rows are deselected.
            </summary>
            <param name="modelObject">Model object to select</param>
            <param name="setFocus">Should the object be focused as well?</param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.SelectObjects(System.Collections.IList)">
            <summary>
            Select the rows that is displaying any of the given model object. All other rows are deselected.
            </summary>
            <param name="modelObjects">A collection of model objects</param>
            <remarks>This method has O(n) performance where n is the number of model objects passed.
            Do not use this to select all the rows in the list -- use SelectAll() for that.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.SetObjects(System.Collections.IEnumerable,System.Boolean)">
            <summary>
            Set the collection of objects that this control will show.
            </summary>
            <param name="collection"></param>
            <param name="preserveState">Should the state of the list be preserved as far as is possible.</param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.BuildList(System.Boolean)">
            <summary>
            Rebuild the list with its current contents.
            </summary>
            <remarks>
            Invalidate any cached information when we rebuild the list.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.ClearCachedInfo">
            <summary>
            Clear any cached info this list may have been using
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.CreateGroups(System.Collections.Generic.IEnumerable{BrightIdeasSoftware.OLVGroup})">
            <summary>
            Do the work of creating groups for this control
            </summary>
            <param name="groups"></param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.DisableVirtualGroups">
            <summary>
            Do the plumbing to disable groups on a virtual list
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.EnableVirtualGroups">
            <summary>
            Do the plumbing to enable groups on a virtual list
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.GetCheckState(System.Object)">
            <summary>
            Get the checkedness of an object from the model. Returning null means the
            model does know and the value from the control will be used.
            </summary>
            <param name="modelObject"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.GetDisplayOrderOfItemIndex(System.Int32)">
            <summary>
            Return the position of the given itemIndex in the list as it currently shown to the user.
            If the control is not grouped, the display order is the same as the
            sorted list order. But if the list is grouped, the display order is different.
            </summary>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.GetLastItemInDisplayOrder">
            <summary>
            Return the last item in the order they are shown to the user.
            If the control is not grouped, the display order is the same as the
            sorted list order. But if the list is grouped, the display order is different.
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.GetNthItemInDisplayOrder(System.Int32)">
            <summary>
            Return the n'th item (0-based) in the order they are shown to the user.
            If the control is not grouped, the display order is the same as the
            sorted list order. But if the list is grouped, the display order is different.
            </summary>
            <param name="n"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.GetNextItem(BrightIdeasSoftware.OLVListItem)">
            <summary>
            Return the ListViewItem that appears immediately after the given item.
            If the given item is null, the first item in the list will be returned.
            Return null if the given item is the last item.
            </summary>
            <param name="itemToFind">The item that is before the item that is returned, or null</param>
            <returns>A OLVListItem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.GetPreviousItem(BrightIdeasSoftware.OLVListItem)">
            <summary>
            Return the ListViewItem that appears immediately before the given item.
            If the given item is null, the last item in the list will be returned.
            Return null if the given item is the first item.
            </summary>
            <param name="itemToFind">The item that is before the item that is returned</param>
            <returns>A ListViewItem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.MakeGroups(BrightIdeasSoftware.GroupingParameters)">
            <summary>
            Make a list of groups that should be shown according to the given parameters
            </summary>
            <param name="parms"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.MakeListViewItem(System.Int32)">
            <summary>
            Create a OLVListItem for given row index
            </summary>
            <param name="itemIndex">The index of the row that is needed</param>
            <returns>An OLVListItem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.PostProcessRows">
            <summary>
            On virtual lists, this cannot work.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.PutCheckState(System.Object,System.Windows.Forms.CheckState)">
            <summary>
            Record the change of checkstate for the given object in the model.
            This does not update the UI -- only the model
            </summary>
            <param name="modelObject"></param>
            <param name="state"></param>
            <returns>The check state that was recorded and that should be used to update
            the control.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.RefreshItem(BrightIdeasSoftware.OLVListItem)">
            <summary>
            Refresh the given item in the list
            </summary>
            <param name="olvi">The item to refresh</param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.SetVirtualListSize(System.Int32)">
            <summary>
            Change the size of the list
            </summary>
            <param name="newSize"></param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.TakeOwnershipOfObjects">
            <summary>
            Take ownership of the 'objects' collection. This separates our collection from the source.
            </summary>
            <remarks>
            <para>
            This method
            separates the 'objects' instance variable from its source, so that any AddObject/RemoveObject
            calls will modify our collection and not the original colleciton.
            </para>
            <para>
            VirtualObjectListViews always own their collections, so this is a no-op.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.UpdateFiltering">
            <summary>
            Change the state of the control to reflect changes in filtering
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.UpdateVirtualListSize">
            <summary>
            Change the size of the virtual list so that it matches its data source
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.HandleCacheVirtualItems(System.Object,System.Windows.Forms.CacheVirtualItemsEventArgs)">
            <summary>
            Handle the CacheVirtualItems event
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.HandleRetrieveVirtualItem(System.Object,System.Windows.Forms.RetrieveVirtualItemEventArgs)">
            <summary>
            Handle a RetrieveVirtualItem
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.HandleSearchForVirtualItem(System.Object,System.Windows.Forms.SearchForVirtualItemEventArgs)">
            <summary>
            Handle the SearchForVirtualList event, which is called when the user types into a virtual list
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualObjectListView.FindMatchInRange(System.String,System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Find the first row in the given range of rows that prefix matches the string value of the given column.
            </summary>
            <param name="text"></param>
            <param name="first"></param>
            <param name="last"></param>
            <param name="column"></param>
            <returns>The index of the matched row, or -1</returns>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.CanShowGroups">
            <summary>
            Gets whether or not this listview is capabale of showing groups
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.CheckBoxes">
            <summary>
            Gets or sets whether this ObjectListView will show checkboxes in the primary column
            </summary>
            <remarks>Due to code in the base ListView class, turning off CheckBoxes on a virtual
            list always throws an InvalidOperationException. This implementation codes around
            that limitation.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.CheckedObjects">
            <summary>
            Get or set the collection of model objects that are checked.
            When setting this property, any row whose model object isn't
            in the given collection will be unchecked. Setting to null is
            equivilent to unchecking all.
            </summary>
            <remarks>
            <para>
            This property returns a simple collection. Changes made to the returned
            collection do NOT affect the list. This is different to the behaviour of
            CheckedIndicies collection.
            </para>
            <para>
            When getting CheckedObjects, the performance of this method is O(n) where n is the number of checked objects.
            When setting CheckedObjects, the performance of this method is O(n) where n is the number of checked objects plus
            the number of objects to be checked.
            </para>
            <para>
            If the ListView is not currently showing CheckBoxes, this property does nothing. It does
            not remember any check box settings made.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.CheckedObjectsMustStillExistInList">
            <summary>
            Gets or sets whether or not an object will be included in the CheckedObjects
            collection, even if it is not present in the control at the moment
            </summary>
            <remarks>
            This property is an implementation detail and should not be altered.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.FilteredObjects">
            <summary>
            Gets the collection of objects that survive any filtering that may be in place.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.GroupingStrategy">
            <summary>
            Gets or sets the strategy that will be used to create groups
            </summary>
            <remarks>
            This must be provided for a virtual list to show groups.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.IsFiltering">
            <summary>
            Gets whether or not the current list is filtering its contents
            </summary>
            <remarks>
            This is only possible if our underlying data source supports filtering.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.Objects">
            <summary>
            Get/set the collection of objects that this list will show
            </summary>
            <remarks>
            <para>
            The contents of the control will be updated immediately after setting this property.
            </para>
            <para>Setting this property preserves selection, if possible. Use SetObjects() if
            you do not want to preserve the selection. Preserving selection is the slowest part of this
            code -- performance is O(n) where n is the number of selected rows.</para>
            <para>This method is not thread safe.</para>
            <para>The property DOES work on virtual lists, but if you try to iterate through a list 
            of 10 million objects, it may take some time :)</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.RowGetter">
            <summary>
            This delegate is used to fetch a rowObject, given it's index within the list
            </summary>
            <remarks>Only use this property if you are not using a VirtualListDataSource.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.ShowGroups">
            <summary>
            Should this list show its items in groups?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.VirtualListDataSource">
            <summary>
            Get/set the data source that is behind this virtual list
            </summary>
            <remarks>Setting this will cause the list to redraw.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualObjectListView.VirtualListSize">
            <summary>
            Gets or sets the number of rows in this virtual list.
            </summary>
            <remarks>
            There is an annoying feature/bug in the .NET ListView class. 
            When you change the VirtualListSize property, it always scrolls so
            that the focused item is the top item. This is annoying since it makes
            the virtual list seem to flicker as the control scrolls to show the focused
            item and then scrolls back to where ObjectListView wants it to be.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.OnExpanding(BrightIdeasSoftware.TreeBranchExpandingEventArgs)">
            <summary>
            Trigger the expanding event
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.OnCollapsing(BrightIdeasSoftware.TreeBranchCollapsingEventArgs)">
            <summary>
            Trigger the collapsing event
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.OnExpanded(BrightIdeasSoftware.TreeBranchExpandedEventArgs)">
            <summary>
            Trigger the expanded event
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.OnCollapsed(BrightIdeasSoftware.TreeBranchCollapsedEventArgs)">
            <summary>
            Trigger the collapsed event
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.#ctor">
            <summary>
            Make a default TreeListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.EnsureTreeRendererPresent(BrightIdeasSoftware.TreeListView.TreeRenderer)">
            <summary>
            Make sure that at least one column is displaying a tree. 
            If no columns is showing the tree, make column 0 do it.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.IsExpanded(System.Object)">
            <summary>
            Return true if the branch at the given model is expanded
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Collapse(System.Object)">
            <summary>
            Collapse the subtree underneath the given model
            </summary>
            <param name="model"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.CollapseAll">
            <summary>
            Collapse all subtrees within this control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.ClearObjects">
            <summary>
            Remove all items from this list
            </summary>
            <remark>This method can safely be called from background threads.</remark>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.DiscardAllState">
            <summary>
            Collapse all roots and forget everything we know about all models
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Expand(System.Object)">
            <summary>
            Expand the subtree underneath the given model object
            </summary>
            <param name="model"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.ExpandAll">
            <summary>
            Expand all the branches within this tree recursively.
            </summary>
            <remarks>Be careful: this method could take a long time for large trees.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.RebuildAll(System.Boolean)">
            <summary>
            Completely rebuild the tree structure
            </summary>
            <param name="preserveState">If true, the control will try to preserve selection and expansion</param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.RebuildAll(System.Collections.IList,System.Collections.IEnumerable,System.Collections.IList)">
            <summary>
            Completely rebuild the tree structure
            </summary>
            <param name="selected">If not null, this list of objects will be selected after the tree is rebuilt</param>
            <param name="expanded">If not null, this collection of objects will be expanded after the tree is rebuilt</param>
            <param name="checkedObjects">If not null, this collection of objects will be checked after the tree is rebuilt</param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Reveal(System.Object,System.Boolean)">
            <summary>
            Unroll all the ancestors of the given model and make sure it is then visible.
            </summary>
            <remarks>This works best when a ParentGetter is installed.</remarks>
            <param name="modelToReveal">The object to be revealed</param>
            <param name="selectAfterReveal">If true, the model will be selected and focused after being revealed</param>
            <returns>True if the object was found and revealed. False if it was not found.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.RefreshObjects(System.Collections.IList)">
            <summary>
            Update the rows that are showing the given objects
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.SetObjectCheckedness(System.Object,System.Windows.Forms.CheckState)">
            <summary>
            Change the check state of the given object to be the given state.
            </summary>
            <remarks>
            If the given model object isn't in the list, we still try to remember
            its state, in case it is referenced in the future.</remarks>
            <param name="modelObject"></param>
            <param name="state"></param>
            <returns>True if the checkedness of the model changed</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.ToggleExpansion(System.Object)">
            <summary>
            Toggle the expanded state of the branch at the given model object
            </summary>
            <param name="model"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.CanExpand(System.Object)">
            <summary>
            Return whether or not the given model can expand.
            </summary>
            <param name="model"></param>
            <remarks>The given model must have already been seen in the tree</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.GetParent(System.Object)">
            <summary>
            Return the model object that is the parent of the given model object.
            </summary>
            <param name="model"></param>
            <returns></returns>
            <remarks>The given model must have already been seen in the tree.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.GetChildren(System.Object)">
            <summary>
            Return the collection of model objects that are the children of the 
            given model as they exist in the tree at the moment.
            </summary>
            <param name="model"></param>
            <remarks>
            <para>
            This method returns the collection of children as the tree knows them. If the given
            model has never been presented to the user (e.g. it belongs to a parent that has
            never been expanded), then this method will return an empty collection.</para>
            <para>
            Because of this, if you want to traverse the whole tree, this is not the method to use.
            It's better to traverse the your data model directly.
            </para>
            <para>
            If the given model has not already been seen in the tree or
            if it is not expandable, an empty collection will be returned.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.ProcessLButtonDown(BrightIdeasSoftware.OlvListViewHitTestInfo)">
            <summary>
            Handle a left button down event
            </summary>
            <param name="hti"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.MakeListViewItem(System.Int32)">
            <summary>
            Create a OLVListItem for given row index
            </summary>
            <param name="itemIndex">The index of the row that is needed</param>
            <returns>An OLVListItem</returns>
            <remarks>This differs from the base method by also setting up the IndentCount property.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.RegenerateTree">
            <summary>
            Reinitialize the Tree structure
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.RecalculateHierarchicalCheckBoxGraph(System.Collections.IList)">
            <summary>
            Recalculate the state of the checkboxes of all the items in the given list
            and their ancestors.
            </summary>
            <remarks>This only makes sense when HierarchicalCheckboxes is true.</remarks>
            <param name="toCheck"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.RecalculateSingleHierarchicalCheckBox(System.Object)">
            <summary>
            Recalculate the hierarchy state of the given item and its ancestors
            </summary>
            <remarks>This only makes sense when HierarchicalCheckboxes is true.</remarks>
            <param name="modelObject"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.CalculateDistinctAncestors(System.Collections.IList)">
            <summary>
            Yield the unique ancestors of the given collection of objects.
            The order of the ancestors is guaranteed to be deeper objects first.
            Roots will always be last.
            </summary>
            <param name="toCheck"></param>
            <returns>Unique ancestors of the given objects</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.GetAncestors(System.Object)">
            <summary>
            Return all the ancestors of the given model
            </summary>
            <remarks>
            <para>
            This uses ParentGetter if possible.
            </para>
            <para>If the given model is a root OR if the model doesn't exist, the collection will be empty</para>
            </remarks>
            <param name="model">The model whose ancestors should be calculated</param>
            <returns>Return a collection of ancestors of the given model.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.HandleApplicationIdle(System.Object,System.EventArgs)">
            <summary>
            The application is idle and a SelectionChanged event has been scheduled
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.IsInputKey(System.Windows.Forms.Keys)">
            <summary>
            Decide if the given key event should be handled as a normal key input to the control?
            </summary>
            <param name="keyData"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.OnKeyDown(System.Windows.Forms.KeyEventArgs)">
            <summary>
            Handle the keyboard input to mimic a TreeView.
            </summary>
            <param name="e"></param>
            <returns>Was the key press handled?</returns>
        </member>
        <member name="E:BrightIdeasSoftware.TreeListView.Expanding">
            <summary>
            This event is triggered when user input requests the expansion of a list item.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.TreeListView.Collapsing">
            <summary>
            This event is triggered when user input requests the collapse of a list item.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.TreeListView.Expanded">
            <summary>
            This event is triggered after the expansion of a list item due to user input.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.TreeListView.Collapsed">
            <summary>
            This event is triggered after the collapse of a list item due to user input.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.CanExpandGetter">
            <summary>
            This is the delegate that will be used to decide if a model object can be expanded.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.CanShowGroups">
            <summary>
            Gets whether or not this listview is capabale of showing groups
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.ChildrenGetter">
            <summary>
            This is the delegate that will be used to fetch the children of a model object
            </summary>
            <remarks>This delegate will only be called if the CanExpand delegate has 
            returned true for the model object.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.ParentGetter">
            <summary>
            This is the delegate that will be used to fetch the parent of a model object
            </summary>
            <returns>The parent of the given model, or null if the model doesn't exist or 
            if the model is a root</returns>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.CheckedObjects">
            <summary>
            Get or set the collection of model objects that are checked.
            When setting this property, any row whose model object isn't
            in the given collection will be unchecked. Setting to null is
            equivilent to unchecking all.
            </summary>
            <remarks>
            <para>
            This property returns a simple collection. Changes made to the returned
            collection do NOT affect the list. This is different to the behaviour of
            CheckedIndicies collection.
            </para>
            <para>
            When getting CheckedObjects, the performance of this method is O(n) where n is the number of checked objects.
            When setting CheckedObjects, the performance of this method is O(n) where n is the number of checked objects plus
            the number of objects to be checked.
            </para>
            <para>
            If the ListView is not currently showing CheckBoxes, this property does nothing. It does
            not remember any check box settings made.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.ExpandedObjects">
            <summary>
            Gets or sets the model objects that are expanded.
            </summary>
            <remarks>
            <para>This can be used to expand model objects before they are seen.</para>
            <para>
            Setting this does *not* force the control to rebuild
            its display. You need to call RebuildAll(true).
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.ListFilter">
            <summary>
            Gets or  sets the filter that is applied to our whole list of objects.
            TreeListViews do not currently support whole list filters.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.HierarchicalCheckboxes">
            <summary>
            Gets or sets whether this tree list view will display hierarchical checkboxes.
            Hierarchical checkboxes is when a parent's "checkedness" is calculated from
            the "checkedness" of its children. If all children are checked, the parent
            will be checked. If all children are unchecked, the parent will also be unchecked.
            If some children are checked and others are not, the parent will be indeterminate.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Objects">
            <summary>
            Gets or sets the collection of root objects of the tree
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.ObjectsForClustering">
            <summary>
            Gets the collection of objects that will be considered when creating clusters
            (which are used to generate Excel-like column filters)
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.RevealAfterExpand">
            <summary>
            After expanding a branch, should the TreeListView attempts to show as much of the 
            revealed descendents as possible.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Roots">
            <summary>
            The model objects that form the top level branches of the tree.
            </summary>
            <remarks>Setting this does <b>NOT</b> reset the state of the control.
            In particular, it does not collapse branches.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.TreeColumnRenderer">
            <summary>
            Gets or sets the renderer that will be used to draw the tree structure.
            Setting this to null resets the renderer to default.
            </summary>
            <remarks>If a column is currently rendering the tree, the renderer
            for that column will be replaced. If no column is rendering the tree,
            column 0 will be given this renderer.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.TreeFactory">
            <summary>
            This is the delegate that will be used to create the underlying Tree structure
            that the TreeListView uses to manage the information about the tree.
            </summary>
            <remarks>
            <para>The factory must not return null. </para>
            <para>
            Most users of TreeListView will never have to use this delegate.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.UseWaitCursorWhenExpanding">
            <summary>
            Should a wait cursor be shown when a branch is being expanded?
            </summary>
            <remarks>When this is true, the wait cursor will be shown whilst the children of the 
            branch are being fetched. If the children of the branch have already been cached, 
            the cursor will not change.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.TreeModel">
            <summary>
            Gets the model that is used to manage the tree structure
            </summary>
            <remarks>
            Don't mess with this property unless you really know what you are doing.
            If you don't already know what it's for, you don't need it.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.TreeRenderer">
            <summary>
            This class handles drawing the tree structure of the primary column.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HighlightTextRenderer">
            <summary>
            This renderer highlights substrings that match a given text filter. 
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.BaseRenderer">
            <summary>
            A BaseRenderer provides useful base level functionality for any custom renderer.
            </summary>
            <remarks>
            <para>Subclasses will normally override the Render or OptionalRender method, and use the other
            methods as helper functions.</para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractRenderer">
            <summary>
            An AbstractRenderer is a do-nothing implementation of the IRenderer interface.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IRenderer">
            <summary>
            Renderers are the mechanism used for owner drawing cells. As such, they can also handle
            hit detection and positioning of cell editing rectangles.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IRenderer.RenderItem(System.Windows.Forms.DrawListViewItemEventArgs,System.Drawing.Graphics,System.Drawing.Rectangle,System.Object)">
            <summary>
            Render the whole item within an ObjectListView. This is only used in non-Details views.
            </summary>
            <param name="e">The event</param>
            <param name="g">A Graphics for rendering</param>
            <param name="itemBounds">The bounds of the item</param>
            <param name="rowObject">The model object to be drawn</param>
            <returns>Return true to indicate that the event was handled and no further processing is needed.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.IRenderer.RenderSubItem(System.Windows.Forms.DrawListViewSubItemEventArgs,System.Drawing.Graphics,System.Drawing.Rectangle,System.Object)">
            <summary>
            Render one cell within an ObjectListView when it is in Details mode.
            </summary>
            <param name="e">The event</param>
            <param name="g">A Graphics for rendering</param>
            <param name="cellBounds">The bounds of the cell</param>
            <param name="rowObject">The model object to be drawn</param>
            <returns>Return true to indicate that the event was handled and no further processing is needed.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.IRenderer.HitTest(BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            What is under the given point?
            </summary>
            <param name="hti"></param>
            <param name="x">x co-ordinate</param>
            <param name="y">y co-ordinate</param>
            <remarks>This method should only alter HitTestLocation and/or UserData.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.IRenderer.GetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            When the value in the given cell is to be edited, where should the edit rectangle be placed?
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractRenderer.RenderItem(System.Windows.Forms.DrawListViewItemEventArgs,System.Drawing.Graphics,System.Drawing.Rectangle,System.Object)">
            <summary>
            Render the whole item within an ObjectListView. This is only used in non-Details views.
            </summary>
            <param name="e">The event</param>
            <param name="g">A Graphics for rendering</param>
            <param name="itemBounds">The bounds of the item</param>
            <param name="rowObject">The model object to be drawn</param>
            <returns>Return true to indicate that the event was handled and no further processing is needed.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractRenderer.RenderSubItem(System.Windows.Forms.DrawListViewSubItemEventArgs,System.Drawing.Graphics,System.Drawing.Rectangle,System.Object)">
            <summary>
            Render one cell within an ObjectListView when it is in Details mode.
            </summary>
            <param name="e">The event</param>
            <param name="g">A Graphics for rendering</param>
            <param name="cellBounds">The bounds of the cell</param>
            <param name="rowObject">The model object to be drawn</param>
            <returns>Return true to indicate that the event was handled and no further processing is needed.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractRenderer.HitTest(BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            What is under the given point?
            </summary>
            <param name="hti"></param>
            <param name="x">x co-ordinate</param>
            <param name="y">y co-ordinate</param>
            <remarks>This method should only alter HitTestLocation and/or UserData.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractRenderer.GetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            When the value in the given cell is to be edited, where should the edit rectangle be placed?
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.AlignRectangle(System.Drawing.Rectangle,System.Drawing.Rectangle)">
            <summary>
            Align the second rectangle with the first rectangle,
            according to the alignment of the column
            </summary>
            <param name="outer">The cell's bounds</param>
            <param name="inner">The rectangle to be aligned within the bounds</param>
            <returns>An aligned rectangle</returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.AlignHorizontally(System.Drawing.Rectangle,System.Drawing.Rectangle)">
            <summary>
            Calculate the left edge of the rectangle that aligns the outer rectangle with the inner one 
            according to this renderer's horizontal alignement
            </summary>
            <param name="outer"></param>
            <param name="inner"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.AlignVertically(System.Drawing.Rectangle,System.Drawing.Rectangle)">
            <summary>
            Calculate the top of the rectangle that aligns the outer rectangle with the inner rectangle
            according to this renders vertical alignment
            </summary>
            <param name="outer"></param>
            <param name="inner"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.AlignVertically(System.Drawing.Rectangle,System.Int32)">
            <summary>
            Calculate the top of the rectangle that aligns the outer rectangle with a rectangle of the given height
            according to this renderer's vertical alignment
            </summary>
            <param name="outer"></param>
            <param name="innerHeight"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.CalculateAlignedRectangle(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Calculate the space that our rendering will occupy and then align that space
            with the given rectangle, according to the Column alignment
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.CalculateCheckBoxBounds(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Calculate the bounds of a checkbox given the cell bounds
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.CalculateCheckBoxWidth(System.Drawing.Graphics)">
            <summary>
            How much space will the check box for this cell occupy?
            </summary>
            <remarks>Only column 0 can have check boxes. Sub item checkboxes are
            treated as images</remarks>
            <param name="g"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.CalculateImageWidth(System.Drawing.Graphics,System.Object)">
            <summary>
            How much horizontal space will the image of this cell occupy?
            </summary>
            <param name="g"></param>
            <param name="imageSelector"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.CalculateTextWidth(System.Drawing.Graphics,System.String)">
            <summary>
            How much horizontal space will the text of this cell occupy?
            </summary>
            <param name="g"></param>
            <param name="txt"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetBackgroundColor">
            <summary>
            Return the Color that is the background color for this item's cell
            </summary>
            <returns>The background color of the subitem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetForegroundColor">
            <summary>
            Return the color to be used for text in this cell
            </summary>
            <returns>The text color of the subitem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetImage">
            <summary>
            Return the image that should be drawn against this subitem
            </summary>
            <returns>An Image or null if no image should be drawn.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetImage(System.Object)">
            <summary>
            Return the actual image that should be drawn when keyed by the given image selector.
            An image selector can be: <list type="bullet">
            <item><description>an int, giving the index into the image list</description></item>
            <item><description>a string, giving the image key into the image list</description></item>
            <item><description>an Image, being the image itself</description></item>
            </list>
            </summary>
            <param name="imageSelector">The value that indicates the image to be used</param>
            <returns>An Image or null</returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetImageSelector">
            <summary>
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetText">
            <summary>
            Return the string that should be drawn within this
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetTextBackgroundColor">
            <summary>
            Return the Color that is the background color for this item's text
            </summary>
            <returns>The background color of the subitem's text</returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.RenderItem(System.Windows.Forms.DrawListViewItemEventArgs,System.Drawing.Graphics,System.Drawing.Rectangle,System.Object)">
            <summary>
            Render the whole item in a non-details view.
            </summary>
            <param name="e"></param>
            <param name="g"></param>
            <param name="itemBounds"></param>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.RenderSubItem(System.Windows.Forms.DrawListViewSubItemEventArgs,System.Drawing.Graphics,System.Drawing.Rectangle,System.Object)">
            <summary>
            Render one cell
            </summary>
            <param name="e"></param>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.HitTest(BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            Calculate which part of this cell was hit
            </summary>
            <param name="hti"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            Calculate the edit rectangle
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.OptionalRender(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our data into the given rectangle using the given graphics context.
            </summary>
            <remarks>
            <para>Subclasses should override this method.</para></remarks>
            <param name="g">The graphics context that should be used for drawing</param>
            <param name="r">The bounds of the subitem cell</param>
            <returns>Returns whether the renderering has already taken place.
            If this returns false, the default processing will take over.
            </returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our data into the given rectangle using the given graphics context.
            </summary>
            <remarks>
            <para>Subclasses should override this method if they never want
            to fall back on the default processing</para></remarks>
            <param name="g">The graphics context that should be used for drawing</param>
            <param name="r">The bounds of the subitem cell</param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.HandleHitTest(System.Drawing.Graphics,BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            Do the actual work of hit testing. Subclasses should override this rather than HitTest()
            </summary>
            <param name="g"></param>
            <param name="hti"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.HandleGetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            Handle a HitTest request after all state information has been initialized
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.StandardRender(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the standard "[checkbox] [image] [text]" cell after the state properties have been initialized.
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.ApplyCellPadding(System.Drawing.Rectangle)">
            <summary>
            Change the bounds of the given rectangle to take any cell padding into account
            </summary>
            <param name="r"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.StandardHitTest(System.Drawing.Graphics,BrightIdeasSoftware.OlvListViewHitTestInfo,System.Drawing.Rectangle,System.Int32,System.Int32)">
            <summary>
            Perform normal hit testing relative to the given bounds
            </summary>
            <param name="g"></param>
            <param name="hti"></param>
            <param name="bounds"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.StandardGetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,System.Drawing.Size)">
            <summary>
            This method calculates the bounds of the text within a standard layout
            (i.e. optional checkbox, optional image, text)
            </summary>
            <remarks>This method only works correctly if the state of the renderer
            has been fully initialized (see BaseRenderer.GetEditRectangle)</remarks>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.CalculatePaddedAlignedBounds(System.Drawing.Graphics,System.Drawing.Rectangle,System.Drawing.Size)">
            <summary>
            Apply any padding to the given bounds, and then align a rectangle of the given
            size within that padded area.
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="preferredSize"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawAlignedImage(System.Drawing.Graphics,System.Drawing.Rectangle,System.Drawing.Image)">
            <summary>
            Draw the given image aligned horizontally within the column.
            </summary>
            <remarks>
            Over tall images are scaled to fit. Over-wide images are
            truncated. This is by design!
            </remarks>
            <param name="g">Graphics context to use for drawing</param>
            <param name="r">Bounds of the cell</param>
            <param name="image">The image to be drawn</param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawAlignedImageAndText(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our subitems image and text
            </summary>
            <param name="g">Graphics context to use for drawing</param>
            <param name="r">Bounds of the cell</param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawBackground(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Fill in the background of this cell
            </summary>
            <param name="g">Graphics context to use for drawing</param>
            <param name="r">Bounds of the cell</param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawCheckBox(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the check box of this row
            </summary>
            <param name="g">Graphics context to use for drawing</param>
            <param name="r">Bounds of the cell</param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.GetCheckBoxState(System.Windows.Forms.CheckState)">
            <summary>
            Calculate the renderer checkboxstate we need to correctly draw the given state
            </summary>
            <param name="checkState"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawImage(System.Drawing.Graphics,System.Drawing.Rectangle,System.Object)">
            <summary>
            Draw the given text and optional image in the "normal" fashion
            </summary>
            <param name="g">Graphics context to use for drawing</param>
            <param name="r">Bounds of the cell</param>
            <param name="imageSelector">The optional image to be drawn</param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawImageAndText(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our subitems image and text
            </summary>
            <param name="g">Graphics context to use for drawing</param>
            <param name="r">Bounds of the cell</param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawImages(System.Drawing.Graphics,System.Drawing.Rectangle,System.Collections.ICollection)">
            <summary>
            Draw the given collection of image selectors
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="imageSelectors"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawText(System.Drawing.Graphics,System.Drawing.Rectangle,System.String)">
            <summary>
            Draw the given text and optional image in the "normal" fashion
            </summary>
            <param name="g">Graphics context to use for drawing</param>
            <param name="r">Bounds of the cell</param>
            <param name="txt">The string to be drawn</param>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawTextGdi(System.Drawing.Graphics,System.Drawing.Rectangle,System.String)">
            <summary>
            Print the given text in the given rectangle using only GDI routines
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="txt"></param>
            <remarks>
            The native list control uses GDI routines to do its drawing, so using them
            here makes the owner drawn mode looks more natural.
            <para>This method doesn't honour the CanWrap setting on the renderer. All
            text is single line</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.BaseRenderer.DrawTextGdiPlus(System.Drawing.Graphics,System.Drawing.Rectangle,System.String)">
            <summary>
            Print the given text in the given rectangle using normal GDI+ .NET methods
            </summary>
            <remarks>Printing to a printer dc has to be done using this method.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.CanWrap">
            <summary>
            Can the renderer wrap lines that do not fit completely within the cell?
            </summary>
            <remarks>Wrapping text doesn't work with the GDI renderer.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.CellPadding">
            <summary>
            Gets or sets how many pixels will be left blank around this cell
            </summary>
            <remarks>
            <para>
            This setting only takes effect when the control is owner drawn.
            </para>
            <para><see cref="P:BrightIdeasSoftware.ObjectListView.CellPadding"/> for more details.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.CellVerticalAlignment">
            <summary>
            Gets or sets how cells drawn by this renderer will be vertically aligned.
            </summary>
            <remarks>
            <para>
            If this is not set, the value from the column or control itself will be used.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.EffectiveCellPadding">
            <summary>
            Gets the optional padding that this renderer should apply before drawing.
            This property considers all possible sources of padding
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.EffectiveCellVerticalAlignment">
            <summary>
            Gets the vertical cell alignment that should govern the rendering.
            This property considers all possible sources.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.ImageList">
            <summary>
            Gets or sets the image list from which keyed images will be fetched
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.Spacing">
            <summary>
            When rendering multiple images, how many pixels should be between each image?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.UseGdiTextRendering">
            <summary>
            Should text be rendered using GDI routines? This makes the text look more
            like a native List view control.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.Aspect">
            <summary>
            Get or set the aspect of the model object that this renderer should draw
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.Bounds">
            <summary>
            What are the bounds of the cell that is being drawn?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.Column">
            <summary>
            Get or set the OLVColumn that this renderer will draw
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.DrawItemEvent">
            <summary>
            Get/set the event that caused this renderer to be called
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.Event">
            <summary>
            Get/set the event that caused this renderer to be called
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.Font">
            <summary>
            Return the font to be used for text in this cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.ImageListOrDefault">
            <summary>
            Gets the image list from which keyed images will be fetched
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.IsDrawBackground">
            <summary>
            Should this renderer fill in the background before drawing?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.IsItemSelected">
            <summary>
            Cache whether or not our item is selected
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.IsPrinting">
            <summary>
            Is this renderer being used on a printer context?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.ListItem">
            <summary>
            Get or set the listitem that this renderer will be drawing
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.ListView">
            <summary>
            Get/set the listview for which the drawing is to be done
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.OLVSubItem">
            <summary>
            Get the specialized OLVSubItem that this renderer is drawing
            </summary>
            <remarks>This returns null for column 0.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.RowObject">
            <summary>
            Get or set the model object that this renderer should draw
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.SubItem">
            <summary>
            Get or set the list subitem that this renderer will be drawing
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.TextBrush">
            <summary>
            The brush that will be used to paint the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.UseCustomCheckboxImages">
            <summary>
            Will this renderer use the custom images from the parent ObjectListView
            to draw the checkbox images.
            </summary>
            <remarks>
            <para>
            If this is true, the renderer will use the images from the 
            StateImageList to represent checkboxes. 0 - unchecked, 1 - checked, 2 - indeterminate.
            </para>
            <para>If this is false (the default), then the renderer will use .NET's standard
            CheckBoxRenderer.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.IsCheckBoxDisabled">
            <summary>
            Should this checkbox be drawn as disabled?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.IsItemHot">
            <summary>
            Is the current item hot (i.e. under the mouse)?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.CellVerticalAlignmentAsTextFormatFlag">
            <summary>
            Gets the cell's vertical alignment as a TextFormatFlag
            </summary>
            <exception cref="T:System.ArgumentOutOfRangeException"></exception>
        </member>
        <member name="P:BrightIdeasSoftware.BaseRenderer.StringFormatForGdiPlus">
            <summary>
            Gets the StringFormat needed when drawing text using GDI+
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.#ctor">
            <summary>
            Create a HighlightTextRenderer
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.#ctor(BrightIdeasSoftware.TextMatchFilter)">
            <summary>
            Create a HighlightTextRenderer
            </summary>
            <param name="filter"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.#ctor(System.String)">
            <summary>
            Create a HighlightTextRenderer
            </summary>
            <param name="text"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.HandleGetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            Handle a HitTest request after all state information has been initialized
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.DrawTextGdi(System.Drawing.Graphics,System.Drawing.Rectangle,System.String)">
            <summary>
            Draw text using GDI
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="txt"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.DrawGdiTextHighlighting(System.Drawing.Graphics,System.Drawing.Rectangle,System.String)">
            <summary>
            Draw the highlighted text using GDI
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="txt"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.DrawSubstringFrame(System.Drawing.Graphics,System.Single,System.Single,System.Single,System.Single)">
            <summary>
            Draw an indication around the given frame that shows a text match
            </summary>
            <param name="g"></param>
            <param name="x"></param>
            <param name="y"></param>
            <param name="width"></param>
            <param name="height"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.DrawTextGdiPlus(System.Drawing.Graphics,System.Drawing.Rectangle,System.String)">
            <summary>
            Draw the text using GDI+
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="txt"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.DrawGdiPlusTextHighlighting(System.Drawing.Graphics,System.Drawing.Rectangle,System.String)">
            <summary>
            Draw the highlighted text using GDI+
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="txt"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.GetRoundedRect(System.Single,System.Single,System.Single,System.Single,System.Single)">
            <summary>
            Return a GraphicPath that is a round cornered rectangle
            </summary>
            <returns>A round cornered rectagle path</returns>
            <remarks>If I could rely on people using C# 3.0+, this should be
            an extension method of GraphicsPath.</remarks>        
            <param name="x"></param>
            <param name="y"></param>
            <param name="width"></param>
            <param name="height"></param>
            <param name="diameter"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HighlightTextRenderer.GetRoundedRect(System.Drawing.RectangleF,System.Single)">
            <summary>
            Return a GraphicPath that is a round cornered rectangle
            </summary>
            <param name="rect">The rectangle</param>
            <param name="diameter">The diameter of the corners</param>
            <returns>A round cornered rectagle path</returns>
            <remarks>If I could rely on people using C# 3.0+, this should be
            an extension method of GraphicsPath.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.HighlightTextRenderer.CornerRoundness">
            <summary>
            Gets or set how rounded will be the corners of the text match frame
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HighlightTextRenderer.FillBrush">
            <summary>
            Gets or set the brush will be used to paint behind the matched substrings.
            Set this to null to not fill the frame.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HighlightTextRenderer.Filter">
            <summary>
            Gets or sets the filter that is filtering the ObjectListView and for
            which this renderer should highlight text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HighlightTextRenderer.FramePen">
            <summary>
            Gets or set the pen will be used to frame the matched substrings.
            Set this to null to not draw a frame.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HighlightTextRenderer.UseRoundedRectangle">
            <summary>
            Gets or sets whether the frame around a text match will have rounded corners
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HighlightTextRenderer.TextToHighlight">
            <summary>
            Gets or set the text that will be highlighted
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HighlightTextRenderer.StringComparison">
            <summary>
            Gets or sets the manner in which substring will be compared.
            </summary>
            <remarks>
            Use this to control if substring matches are case sensitive or insensitive.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.HighlightTextRenderer.ShouldDrawHighlighting">
            <summary>
            Gets whether the renderer should actually draw highlighting
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.TreeRenderer.#ctor">
            <summary>
            Create a TreeRenderer
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.TreeListView.TreeRenderer.PIXELS_PER_LEVEL">
            <summary>
            How many pixels will be reserved for each level of indentation?
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.TreeRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            The real work of drawing the tree is done in this method
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.TreeRenderer.DrawExpansionGlyph(System.Drawing.Graphics,System.Drawing.Rectangle,System.Boolean)">
            <summary>
            Draw the expansion indicator
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="isExpanded"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.TreeRenderer.DrawExpansionGlyphStyled(System.Drawing.Graphics,System.Drawing.Rectangle,System.Boolean)">
            <summary>
            Draw the expansion indicator using styles
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="isExpanded"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.TreeRenderer.DrawExpansionGlyphManual(System.Drawing.Graphics,System.Drawing.Rectangle,System.Boolean)">
            <summary>
            Draw the expansion indicator without using styles
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="isExpanded"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.TreeRenderer.DrawLines(System.Drawing.Graphics,System.Drawing.Rectangle,System.Drawing.Pen,BrightIdeasSoftware.TreeListView.Branch,System.Int32)">
            <summary>
            Draw the lines of the tree
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="p"></param>
            <param name="br"></param>
            <param name="glyphMidVertical"> </param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.TreeRenderer.HandleHitTest(System.Drawing.Graphics,BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            Do the hit test
            </summary>
            <param name="g"></param>
            <param name="hti"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.TreeRenderer.HandleGetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            Calculate the edit rect
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.TreeRenderer.Branch">
            <summary>
            Return the branch that the renderer is currently drawing.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.TreeRenderer.LinePen">
            <summary>
            Return the pen that will be used to draw the lines between branches
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.TreeRenderer.TreeListView">
            <summary>
            Return the TreeListView for which the renderer is being used.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.TreeRenderer.IsShowLines">
            <summary>
            Should the renderer draw lines connecting siblings?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.TreeRenderer.UseStyles">
            <summary>
            Gets whether or not we should render using styles
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.CanExpandGetterDelegate">
            <summary>
            Delegates of this type are use to decide if the given model object can be expanded
            </summary>
            <param name="model">The model under consideration</param>
            <returns>Can the given model be expanded?</returns>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.ChildrenGetterDelegate">
            <summary>
            Delegates of this type are used to fetch the children of the given model object
            </summary>
            <param name="model">The parent whose children should be fetched</param>
            <returns>An enumerable over the children</returns>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.ParentGetterDelegate">
            <summary>
            Delegates of this type are used to fetch the parent of the given model object.
            </summary>
            <param name="model">The child whose parent should be fetched</param>
            <returns>The parent of the child or null if the child is a root</returns>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.TreeFactoryDelegate">
            <summary>
            Delegates of this type are used to create a new underlying Tree structure.
            </summary>
            <param name="view">The view for which the Tree is being created</param>
            <returns>A subclass of Tree</returns>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.Tree">
            <summary>
            A Tree object represents a tree structure data model that supports both 
            tree and flat list operations as well as fast access to branches.
            </summary>
            <remarks>If you create a subclass of Tree, you must install it in the TreeListView
            via the TreeFactory delegate.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.IVirtualListDataSource">
            <summary>
            A VirtualListDataSource is a complete manner to provide functionality to a virtual list.
            An object that implements this interface provides a VirtualObjectListView with all the
            information it needs to be fully functional.
            </summary>
            <remarks>Implementors must provide functioning implementations of at least GetObjectCount()
            and GetNthObject(), otherwise nothing will appear in the list.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.GetNthObject(System.Int32)">
            <summary>
            Return the object that should be displayed at the n'th row.
            </summary>
            <param name="n">The index of the row whose object is to be returned.</param>
            <returns>The model object at the n'th row, or null if the fetching was unsuccessful.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.GetObjectCount">
            <summary>
            Return the number of rows that should be visible in the virtual list
            </summary>
            <returns>The number of rows the list view should have.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.GetObjectIndex(System.Object)">
            <summary>
            Get the index of the row that is showing the given model object
            </summary>
            <param name="model">The model object sought</param>
            <returns>The index of the row showing the model, or -1 if the object could not be found.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.PrepareCache(System.Int32,System.Int32)">
            <summary>
            The ListView is about to request the given range of items. Do
            whatever caching seems appropriate.
            </summary>
            <param name="first"></param>
            <param name="last"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.SearchText(System.String,System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Find the first row that "matches" the given text in the given range.
            </summary>
            <param name="value">The text typed by the user</param>
            <param name="first">Start searching from this index. This may be greater than the 'to' parameter, 
            in which case the search should descend</param>
            <param name="last">Do not search beyond this index. This may be less than the 'from' parameter.</param>
            <param name="column">The column that should be considered when looking for a match.</param>
            <returns>Return the index of row that was matched, or -1 if no match was found</returns>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.Sort(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Sort the model objects in the data source.
            </summary>
            <param name="column"></param>
            <param name="order"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.AddObjects(System.Collections.ICollection)">
            <summary>
            Add the given collection of model objects to this control.
            </summary>
            <param name="modelObjects">A collection of model objects</param>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.RemoveObjects(System.Collections.ICollection)">
            <summary>
            Remove all of the given objects from the control
            </summary>
            <param name="modelObjects">Collection of objects to be removed</param>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.SetObjects(System.Collections.IEnumerable)">
            <summary>
            Set the collection of objects that this control will show.
            </summary>
            <param name="collection"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualListDataSource.UpdateObject(System.Int32,System.Object)">
            <summary>
            Update/replace the nth object with the given object
            </summary>
            <param name="index"></param>
            <param name="modelObject"></param>
        </member>
        <member name="T:BrightIdeasSoftware.IFilterableDataSource">
            <summary>
            This extension allow virtual lists to filter their contents
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IFilterableDataSource.ApplyFilters(BrightIdeasSoftware.IModelFilter,BrightIdeasSoftware.IListFilter)">
            <summary>
            All subsequent retrievals on this data source should be filtered
            through the given filters. null means no filtering of that kind.
            </summary>
            <param name="modelFilter"></param>
            <param name="listFilter"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.#ctor(BrightIdeasSoftware.TreeListView)">
            <summary>
            Create a Tree
            </summary>
            <param name="treeView"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.Collapse(System.Object)">
            <summary>
            Collapse the subtree underneath the given model
            </summary>
            <param name="model">The model to be collapsed. If the model isn't in the tree,
            or if it is already collapsed, the command does nothing.</param>
            <returns>The index of the model in flat list version of the tree</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.CollapseAll">
            <summary>
            Collapse all branches in this tree
            </summary>
            <returns>Return the index of the first root that was not collapsed</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.Expand(System.Object)">
            <summary>
            Expand the subtree underneath the given model object
            </summary>
            <param name="model">The model to be expanded.</param> 
            <returns>The index of the model in flat list version of the tree</returns>
            <remarks>
            If the model isn't in the tree,
            if it cannot be expanded or if it is already expanded, the command does nothing.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.ExpandAll">
            <summary>
            Expand all branches in this tree
            </summary>
            <returns>Return the index of the first branch that was expanded</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.GetBranch(System.Object)">
            <summary>
            Return the Branch object that represents the given model in the tree
            </summary>
            <param name="model">The model whose branches is to be returned</param>
            <returns>The branch that represents the given model, or null if the model
            isn't in the tree.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.GetVisibleDescendentCount(System.Object)">
            <summary>
            Return the number of visible descendents that are below the given model.
            </summary>
            <param name="model">The model whose descendent count is to be returned</param>
            <returns>The number of visible descendents. 0 if the model doesn't exist or is collapsed</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.RebuildChildren(System.Object)">
            <summary>
            Rebuild the children of the given model, refreshing any cached information held about the given object
            </summary>
            <param name="model"></param>
            <returns>The index of the model in flat list version of the tree</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.IsModelExpanded(System.Object)">
            <summary>
            Is the given model expanded?
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.SetModelExpanded(System.Object,System.Boolean)">
            <summary>
            Remember whether or not the given model was expanded
            </summary>
            <param name="model"></param>
            <param name="isExpanded"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.InsertChildren(BrightIdeasSoftware.TreeListView.Branch,System.Int32)">
            <summary>
            Insert the children of the given branch into the given position
            </summary>
            <param name="br">The branch whose children should be inserted</param>
            <param name="index">The index where the children should be inserted</param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.RebuildList">
            <summary>
            Rebuild our flat internal list of objects.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.RebuildObjectMap(System.Int32)">
            <summary>
            Rebuild our reverse index that maps an object to its location
            in the filteredObjectList array.
            </summary>
            <param name="startIndex"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.MakeBranch(BrightIdeasSoftware.TreeListView.Branch,System.Object)">
            <summary>
            Create a new branch within this tree
            </summary>
            <param name="parent"></param>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.GetNthObject(System.Int32)">
            <summary>
            
            </summary>
            <param name="n"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.GetObjectCount">
            <summary>
            
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.GetObjectIndex(System.Object)">
            <summary>
            
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.PrepareCache(System.Int32,System.Int32)">
            <summary>
            
            </summary>
            <param name="first"></param>
            <param name="last"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.SearchText(System.String,System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn)">
            <summary>
            
            </summary>
            <param name="value"></param>
            <param name="first"></param>
            <param name="last"></param>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.Sort(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Sort the tree on the given column and in the given order
            </summary>
            <param name="column"></param>
            <param name="order"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.GetBranchComparer">
            <summary>
            
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.AddObjects(System.Collections.ICollection)">
            <summary>
            Add the given collection of objects to the roots of this tree
            </summary>
            <param name="modelObjects"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.RemoveObjects(System.Collections.ICollection)">
            <summary>
            Remove all of the given objects from the roots of the tree.
            Any objects that is not already in the roots collection is ignored.
            </summary>
            <param name="modelObjects"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.SetObjects(System.Collections.IEnumerable)">
            <summary>
            Set the roots of this tree to be the given collection
            </summary>
            <param name="collection"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.UpdateObject(System.Int32,System.Object)">
            <summary>
            Update/replace the nth object with the given object
            </summary>
            <param name="index"></param>
            <param name="modelObject"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.ApplyFilters(BrightIdeasSoftware.IModelFilter,BrightIdeasSoftware.IListFilter)">
            <summary>
            
            </summary>
            <param name="mFilter"></param>
            <param name="lFilter"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Tree.IncludeModel(System.Object)">
            <summary>
            Should the given model be included in this control?
            </summary>
            <param name="model">The model to consider</param>
            <returns>True if it will be included</returns>
        </member>
        <member name="F:BrightIdeasSoftware.TreeListView.Tree.modelFilter">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.TreeListView.Tree.listFilter">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Tree.CanExpandGetter">
            <summary>
            This is the delegate that will be used to decide if a model object can be expanded.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Tree.ChildrenGetter">
            <summary>
            This is the delegate that will be used to fetch the children of a model object
            </summary>
            <remarks>This delegate will only be called if the CanExpand delegate has 
            returned true for the model object.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Tree.RootObjects">
            <summary>
            Get or return the top level model objects in the tree
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Tree.TreeView">
            <summary>
            What tree view is this Tree the model for?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Tree.IsFiltering">
            <summary>
            Is this list currently being filtered?
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.Branch">
            <summary>
            A Branch represents a sub-tree within a tree
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.#ctor(BrightIdeasSoftware.TreeListView.Branch,BrightIdeasSoftware.TreeListView.Tree,System.Object)">
            <summary>
            Create a Branch
            </summary>
            <param name="parent"></param>
            <param name="tree"></param>
            <param name="model"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.ClearCachedInfo">
            <summary>
            Clear any cached information that this branch is holding
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.Collapse">
            <summary>
            Collapse this branch
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.Expand">
            <summary>
            Expand this branch
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.ExpandAll">
            <summary>
            Expand this branch recursively
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.FetchChildren">
            <summary>
            Fetch the children of this branch.
            </summary>
            <remarks>This should only be called when CanExpand is true.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.Flatten">
            <summary>
            Collapse the visible descendents of this branch into list of model objects
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.FlattenOnto(System.Collections.IList)">
            <summary>
            Flatten this branch's visible descendents onto the given list.
            </summary>
            <param name="flatList"></param>
            <remarks>The branch itself is <b>not</b> included in the list.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.RefreshChildren">
            <summary>
            Force a refresh of all children recursively
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.Branch.Sort(BrightIdeasSoftware.TreeListView.BranchComparer)">
            <summary>
            Sort the sub-branches and their descendents so they are ordered according
            to the given comparer.
            </summary>
            <param name="comparer">The comparer that orders the branches</param>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.Ancestors">
            <summary>
            Get the ancestor branches of this branch, with the 'oldest' ancestor first.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.CanExpand">
            <summary>
            Can this branch be expanded?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.ChildBranches">
            <summary>
            Gets or sets our children
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.Children">
            <summary>
            Get/set the model objects that are beneath this branch
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.FilteredChildBranches">
            <summary>
            Gets a list of all the branches that survive filtering
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.IsExpanded">
            <summary>
            Gets or set whether this branch is expanded
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.IsFirstBranch">
            <summary>
            Return true if this branch is the first branch of the entire tree
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.IsLastChild">
            <summary>
            Return true if this branch is the last child of its parent
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.IsOnlyBranch">
            <summary>
            Return true if this branch is the only top level branch
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.Level">
            <summary>
            Gets the depth level of this branch
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.Model">
            <summary>
            Gets or sets which model is represented by this branch
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.NumberVisibleDescendents">
            <summary>
            Return the number of descendents of this branch that are currently visible
            </summary>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.ParentBranch">
            <summary>
            Gets or sets our parent branch
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.Tree">
            <summary>
            Gets or sets our overall tree
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeListView.Branch.Visible">
            <summary>
            Is this branch currently visible? A branch is visible
            if it has no parent (i.e. it's a root), or its parent
            is visible and expanded.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.Branch.BranchFlags">
            <summary>
            Indicators for branches
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.TreeListView.Branch.BranchFlags.FirstBranch">
            <summary>
            FirstBranch of tree
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.TreeListView.Branch.BranchFlags.LastChild">
            <summary>
            LastChild of parent
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.TreeListView.Branch.BranchFlags.OnlyBranch">
            <summary>
            OnlyBranch of tree
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeListView.BranchComparer">
            <summary>
            This class sorts branches according to how their respective model objects are sorted
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.BranchComparer.#ctor(System.Collections.IComparer)">
            <summary>
            Create a BranchComparer
            </summary>
            <param name="actualComparer"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeListView.BranchComparer.Compare(BrightIdeasSoftware.TreeListView.Branch,BrightIdeasSoftware.TreeListView.Branch)">
            <summary>
            Order the two branches
            </summary>
            <param name="x"></param>
            <param name="y"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.DataTreeListView.DataSource">
            <summary>
            Get or set the DataSource that will be displayed in this list view.
            </summary>
            <remarks>The DataSource should implement either <see cref="T:System.Collections.IList"/>, <see cref="T:System.ComponentModel.IBindingList"/>,
            or <see cref="T:System.ComponentModel.IListSource"/>. Some common examples are the following types of objects:
            <list type="unordered">
            <item><description><see cref="T:System.Data.DataView"/></description></item>
            <item><description><see cref="T:System.Data.DataTable"/></description></item>
            <item><description><see cref="T:System.Data.DataSet"/></description></item>
            <item><description><see cref="T:System.Data.DataViewManager"/></description></item>
            <item><description><see cref="T:System.Windows.Forms.BindingSource"/></description></item>
            </list>
            <para>When binding to a list container (i.e. one that implements the
            <see cref="T:System.ComponentModel.IListSource"/> interface, such as <see cref="T:System.Data.DataSet"/>)
            you must also set the <see cref="P:BrightIdeasSoftware.DataTreeListView.DataMember"/> property in order
            to identify which particular list you would like to display. You
            may also set the <see cref="P:BrightIdeasSoftware.DataTreeListView.DataMember"/> property even when
            DataSource refers to a list, since <see cref="P:BrightIdeasSoftware.DataTreeListView.DataMember"/> can
            also be used to navigate relations between lists.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataTreeListView.DataMember">
            <summary>
            Gets or sets the name of the list or table in the data source for which the DataListView is displaying data.
            </summary>
            <remarks>If the data source is not a DataSet or DataViewManager, this property has no effect</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataTreeListView.KeyAspectName">
            <summary>
            Gets or sets the name of the property/column that uniquely identifies each row.
            </summary>
            <remarks>
            <para>
            The value contained by this column must be unique across all rows 
            in the data source. Odd and unpredictable things will happen if two
            rows have the same id.
            </para>
            <para>Null cannot be a valid key value.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataTreeListView.ParentKeyAspectName">
            <summary>
            Gets or sets the name of the property/column that contains the key of
            the parent of a row.
            </summary>
            <remarks>
            <para>
            The test condition for deciding if one row is the parent of another is functionally
            equivilent to this:
            <code>
            Object.Equals(candidateParentRow[this.KeyAspectName], row[this.ParentKeyAspectName])
            </code>
            </para>
            <para>Unlike key value, parent keys can be null but a null parent key can only be used
            to identify root objects.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataTreeListView.RootKeyValue">
            <summary>
            Gets or sets the value that identifies a row as a root object.
            When the ParentKey of a row equals the RootKeyValue, that row will
            be treated as root of the TreeListView.
            </summary>
            <remarks>
            <para>
            The test condition for deciding a root object is functionally
            equivilent to this:
            <code>
            Object.Equals(candidateRow[this.ParentKeyAspectName], this.RootKeyValue)
            </code>
            </para>
            <para>The RootKeyValue can be null. Actually, it can be any value that can 
            be compared for equality against a basic type.</para>
            <para>If this is set to the wrong value (i.e. to a value that no row
            has in the parent id column), the list will be empty.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataTreeListView.RootKeyValueString">
            <summary>
            Gets or sets the value that identifies a row as a root object.
            <see cref="P:BrightIdeasSoftware.DataTreeListView.RootKeyValue"/>. The RootKeyValue can be of any type,
            but the IDE cannot sensibly represent a value of any type,
            so this is a typed wrapper around that property.
            </summary>
            <remarks>
            If you want the root value to be something other than a string,
            you will have set it yourself.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataTreeListView.ShowKeyColumns">
            <summary>
            Gets or sets whether or not the key columns (id and parent id) should
            be shown to the user.
            </summary>
            <remarks>This must be set before the DataSource is set. It has no effect
            afterwards.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataTreeListView.Adapter">
            <summary>
            Gets or sets the DataSourceAdaptor that does the bulk of the work needed
            for data binding.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVDataObject">
            <summary>
            A data transfer object that knows how to transform a list of model
            objects into a text and HTML representation.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVDataObject.#ctor(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Create a data object from the selected objects in the given ObjectListView
            </summary>
            <param name="olv">The source of the data object</param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVDataObject.#ctor(BrightIdeasSoftware.ObjectListView,System.Collections.IList)">
            <summary>
            Create a data object which operates on the given model objects 
            in the given ObjectListView
            </summary>
            <param name="olv">The source of the data object</param>
            <param name="modelObjects">The model objects to be put into the data object</param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVDataObject.CreateTextFormats">
            <summary>
            Put a text and HTML representation of our model objects
            into the data object.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVDataObject.CreateExporter">
            <summary>
            Create an exporter for the data contained in this object
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVDataObject.CreateHtml">
            <summary>
            Make a HTML representation of our model objects
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVDataObject.ConvertToHtmlFragment(System.String)">
            <summary>
            Convert the fragment of HTML into the Clipboards HTML format.
            </summary>
            <remarks>The HTML format is found here http://msdn2.microsoft.com/en-us/library/aa767917.aspx
            </remarks>
            <param name="fragment">The HTML to put onto the clipboard. It must be valid HTML!</param>
            <returns>A string that can be put onto the clipboard and will be recognized as HTML</returns>
        </member>
        <member name="P:BrightIdeasSoftware.OLVDataObject.IncludeHiddenColumns">
            <summary>
            Gets or sets whether hidden columns will also be included in the text
            and HTML representation. If this is false, only visible columns will
            be included.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVDataObject.IncludeColumnHeaders">
            <summary>
            Gets or sets whether column headers will also be included in the text
            and HTML representation.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVDataObject.ListView">
            <summary>
            Gets the ObjectListView that is being used as the source of the data
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVDataObject.ModelObjects">
            <summary>
            Gets the model objects that are to be placed in the data object
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.DateTimePortion">
            <summary>
            This enum is used to indicate various portions of a datetime
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DateTimePortion.Year">
            <summary>
            Year
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DateTimePortion.Month">
            <summary>
            Month
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DateTimePortion.Day">
            <summary>
            Day of the month
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DateTimePortion.Hour">
            <summary>
            Hour
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DateTimePortion.Minute">
            <summary>
            Minute
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DateTimePortion.Second">
            <summary>
            Second
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.DateTimeClusteringStrategy">
            <summary>
            This class implements a strategy where the model objects are clustered
            according to some portion of the datetime value in the configured column.
            </summary>
            <remarks>To create a strategy that grouped people who were born in
            the same month, you would create a strategy that extracted just
            the month, and formatted it to show just the month's name. Like this:
            </remarks>
            <example>
            someColumn.ClusteringStrategy = new DateTimeClusteringStrategy(DateTimePortion.Month, "MMMM");
            </example>
        </member>
        <member name="T:BrightIdeasSoftware.ClusteringStrategy">
            <summary>
            This class provides a useful base implemention of a clustering
            strategy where the clusters are grouped around the value of a given column.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IClusteringStrategy">
            <summary>
            Implementation of this interface control the selecting of cluster keys
            and how those clusters will be presented to the user
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IClusteringStrategy.GetClusterKey(System.Object)">
            <summary>
            Get the cluster key by which the given model will be partitioned by this strategy
            </summary>
            <remarks>If the returned value is an IEnumerable, the given model is considered
            to belong to multiple clusters</remarks>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.IClusteringStrategy.CreateCluster(System.Object)">
            <summary>
            Create a cluster to hold the given cluster key
            </summary>
            <param name="clusterKey"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.IClusteringStrategy.GetClusterDisplayLabel(BrightIdeasSoftware.ICluster)">
            <summary>
            Gets the display label that the given cluster should use
            </summary>
            <param name="cluster"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.IClusteringStrategy.CreateFilter(System.Collections.IList)">
            <summary>
            Create a filter that will include only model objects that
            match one or more of the given values.
            </summary>
            <param name="valuesChosenForFiltering"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.IClusteringStrategy.Column">
            <summary>
            Gets or sets the column upon which this strategy will operate
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ClusteringStrategy.NULL_LABEL">
            <summary>
            This field is the text that will be shown to the user when a cluster
            key is null. It is exposed so it can be localized.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ClusteringStrategy.EMPTY_LABEL">
            <summary>
            This field is the text that will be shown to the user when a cluster
            key is empty (i.e. a string of zero length). It is exposed so it can be localized.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ClusteringStrategy.#ctor">
            <summary>
            Create a clustering strategy
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ClusteringStrategy.GetClusterKey(System.Object)">
            <summary>
            Get the cluster key by which the given model will be partitioned by this strategy
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ClusteringStrategy.CreateCluster(System.Object)">
            <summary>
            Create a cluster to hold the given cluster key
            </summary>
            <param name="clusterKey"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ClusteringStrategy.GetClusterDisplayLabel(BrightIdeasSoftware.ICluster)">
            <summary>
            Gets the display label that the given cluster should use
            </summary>
            <param name="cluster"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ClusteringStrategy.CreateFilter(System.Collections.IList)">
            <summary>
            Create a filter that will include only model objects that
            match one or more of the given values.
            </summary>
            <param name="valuesChosenForFiltering"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ClusteringStrategy.ApplyDisplayFormat(BrightIdeasSoftware.ICluster,System.String)">
            <summary>
            Create a label that combines the string representation of the cluster
            key with a format string that holds an "X [N items in cluster]" type layout.
            </summary>
            <param name="cluster"></param>
            <param name="s"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.ClusteringStrategy.DefaultDisplayLabelFormatSingular">
            <summary>
            Gets or sets the format that will be used by default for clusters that only
            contain 1 item. The format string must accept two placeholders:
            - {0} is the cluster key converted to a string
            - {1} is the number of items in the cluster (always 1 in this case)
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ClusteringStrategy.DefaultDisplayLabelFormatPlural">
            <summary>
            Gets or sets the format that will be used by default for clusters that 
            contain 0 or two or more items. The format string must accept two placeholders:
            - {0} is the cluster key converted to a string
            - {1} is the number of items in the cluster
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ClusteringStrategy.Column">
            <summary>
            Gets or sets the column upon which this strategy is operating
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ClusteringStrategy.DisplayLabelFormatSingular">
            <summary>
            Gets or sets the format that will be used when the cluster
            contains only 1 item. The format string must accept two placeholders:
            - {0} is the cluster key converted to a string
            - {1} is the number of items in the cluster (always 1 in this case)
            </summary>
            <remarks>If this is not set, the value from 
            ClusteringStrategy.DefaultDisplayLabelFormatSingular will be used</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ClusteringStrategy.DisplayLabelFormatPlural">
            <summary>
            Gets or sets the format that will be used when the cluster 
            contains 0 or two or more items. The format string must accept two placeholders:
            - {0} is the cluster key converted to a string
            - {1} is the number of items in the cluster
            </summary>
            <remarks>If this is not set, the value from 
            ClusteringStrategy.DefaultDisplayLabelFormatPlural will be used</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.DateTimeClusteringStrategy.#ctor">
            <summary>
            Create a strategy that clusters by month/year
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DateTimeClusteringStrategy.#ctor(BrightIdeasSoftware.DateTimePortion,System.String)">
            <summary>
            Create a strategy that clusters around the given parts
            </summary>
            <param name="portions"></param>
            <param name="format"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DateTimeClusteringStrategy.GetClusterKey(System.Object)">
            <summary>
            Get the cluster key by which the given model will be partitioned by this strategy
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.DateTimeClusteringStrategy.GetClusterDisplayLabel(BrightIdeasSoftware.ICluster)">
            <summary>
            Gets the display label that the given cluster should use
            </summary>
            <param name="cluster"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.DateTimeClusteringStrategy.DateToString(System.DateTime)">
            <summary>
            Convert the given date into a user presentable string
            </summary>
            <param name="dateTime"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.DateTimeClusteringStrategy.Format">
            <summary>
            Gets or sets the format string will will be used to create a user-presentable
            version of the cluster key.
            </summary>
            <remarks>The format should use the date/time format strings, as documented
            in the Windows SDK. Both standard formats and custom format will work.</remarks>
            <example>"D" - long date pattern</example>
            <example>"MMMM, yyyy" - "January, 1999"</example>
        </member>
        <member name="P:BrightIdeasSoftware.DateTimeClusteringStrategy.Portions">
            <summary>
            Gets or sets the parts of the DateTime that will be extracted when
            determining the clustering key for an object.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FlagClusteringStrategy">
            <summary>
            Instances of this class cluster model objects on the basis of a
            property that holds an xor-ed collection of bit flags.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.FlagClusteringStrategy.#ctor(System.Type)">
            <summary>
            Create a clustering strategy that operates on the flags of the given enum
            </summary>
            <param name="enumType"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FlagClusteringStrategy.#ctor(System.Int64[],System.String[])">
            <summary>
            Create a clustering strategy around the given collections of flags and their display labels.
            There must be the same number of elements in both collections.
            </summary>
            <param name="values">The list of flags. </param>
            <param name="labels"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FlagClusteringStrategy.GetClusterKey(System.Object)">
            <summary>
            Get the cluster key by which the given model will be partitioned by this strategy
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FlagClusteringStrategy.GetClusterDisplayLabel(BrightIdeasSoftware.ICluster)">
            <summary>
            Gets the display label that the given cluster should use
            </summary>
            <param name="cluster"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FlagClusteringStrategy.CreateFilter(System.Collections.IList)">
            <summary>
            Create a filter that will include only model objects that
            match one or more of the given values.
            </summary>
            <param name="valuesChosenForFiltering"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.FlagClusteringStrategy.Values">
            <summary>
            Gets the value that will be xor-ed to test for the presence of a particular value.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FlagClusteringStrategy.Labels">
            <summary>
            Gets the labels that will be used when the corresponding Value is XOR present in the data.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TextMatchFilter">
            <summary>
            Instances of this class include only those rows of the listview
            that match one or more given strings.
            </summary>
            <remarks>This class can match strings by prefix, regex, or simple containment.
            There are factory methods for each of these matching strategies.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractModelFilter">
            <summary>
            Base class for model-by-model filters
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IModelFilter">
            <summary>
            Interface for model-by-model filtering
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IModelFilter.Filter(System.Object)">
            <summary>
            Should the given model be included when this filter is installed
            </summary>
            <param name="modelObject">The model object to consider</param>
            <returns>Returns true if the model will be included by the filter</returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractModelFilter.Filter(System.Object)">
            <summary>
            Should the given model be included when this filter is installed
            </summary>
            <param name="modelObject">The model object to consider</param>
            <returns>Returns true if the model will be included by the filter</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.Regex(BrightIdeasSoftware.ObjectListView,System.String[])">
            <summary>
            Create a text filter that will include rows where any cell matches 
            any of the given regex expressions.
            </summary>
            <param name="olv"></param>
            <param name="texts"></param>
            <returns></returns>
            <remarks>Any string that is not a valid regex expression will be ignored.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.Prefix(BrightIdeasSoftware.ObjectListView,System.String[])">
            <summary>
            Create a text filter that includes rows where any cell begins with one of the given strings
            </summary>
            <param name="olv"></param>
            <param name="texts"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.Contains(BrightIdeasSoftware.ObjectListView,System.String[])">
            <summary>
            Create a text filter that includes rows where any cell contains any of the given strings.
            </summary>
            <param name="olv"></param>
            <param name="texts"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.#ctor(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Create a TextFilter
            </summary>
            <param name="olv"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.#ctor(BrightIdeasSoftware.ObjectListView,System.String)">
            <summary>
            Create a TextFilter that finds the given string
            </summary>
            <param name="olv"></param>
            <param name="text"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.#ctor(BrightIdeasSoftware.ObjectListView,System.String,System.StringComparison)">
            <summary>
            Create a TextFilter that finds the given string using the given comparison
            </summary>
            <param name="olv"></param>
            <param name="text"></param>
            <param name="comparison"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.IterateColumns">
            <summary>
            Loop over the columns that are being considering by the filter
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.Filter(System.Object)">
            <summary>
            Do the actual work of filtering
            </summary>
            <param name="modelObject"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.FindAllMatchedRanges(System.String)">
            <summary>
            Find all the ways in which this filter matches the given string.
            </summary>
            <remarks>This is used by the renderer to decide which bits of
            the string should be highlighted</remarks>
            <param name="cellText"></param>
            <returns>A list of character ranges indicating the matched substrings</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.IsIncluded(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Is the given column one of the columns being used by this filter?
            </summary>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.Columns">
            <summary>
            Gets or sets which columns will be used for the comparisons? If this is null, all columns will be used
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.AdditionalColumns">
            <summary>
            Gets or sets additional columns which will be used in the comparison. These will be used
            in addition to either the Columns property or to all columns taken from the control.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.ContainsStrings">
            <summary>
            Gets or sets the collection of strings that will be used for 
            contains matching. Setting this replaces all previous texts
            of any kind.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.HasComponents">
            <summary>
            Gets whether or not this filter has any search criteria
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.ListView">
            <summary>
            Gets or set the ObjectListView upon which this filter will work
            </summary>
            <remarks>
            You cannot really rebase a filter after it is created, so do not change this value.
            It is included so that it can be set in an object initializer.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.PrefixStrings">
            <summary>
            Gets or sets the collection of strings that will be used for 
            prefix matching. Setting this replaces all previous texts
            of any kind.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.RegexOptions">
            <summary>
            Gets or sets the options that will be used when compiling the regular expression.
            </summary>
            <remarks>
            This is only used when doing Regex matching (obviously).
            If this is not set specifically, the appropriate options are chosen to match the
            StringComparison setting (culture invariant, case sensitive).
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.RegexStrings">
            <summary>
            Gets or sets the collection of strings that will be used for 
            regex pattern matching. Setting this replaces all previous texts
            of any kind.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.StringComparison">
            <summary>
            Gets or  sets how the filter will match text
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TextMatchFilter.TextMatchingStrategy">
            <summary>
            Base class for the various types of string matching that TextMatchFilter provides
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextMatchingStrategy.FindAllMatchedRanges(System.String)">
            <summary>
            Find all the ways in which this filter matches the given string.
            </summary>
            <remarks>
            <para>
            This is used by the renderer to decide which bits of
            the string should be highlighted.
            </para>
            <para>this.Text will not be null or empty when this is called.</para>
            </remarks>
            <param name="cellText">The text of the cell we want to search</param>
            <returns>A list of character ranges indicating the matched substrings</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextMatchingStrategy.MatchesText(System.String)">
            <summary>
            Does the given text match the filter
            </summary>
            <remarks>
            <para>this.Text will not be null or empty when this is called.</para>
            </remarks>
            <param name="cellText">The text of the cell we want to search</param>
            <returns>Return true if the given cellText matches our strategy</returns>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.TextMatchingStrategy.StringComparison">
            <summary>
            Gets how the filter will match text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.TextMatchingStrategy.TextFilter">
            <summary>
            Gets the text filter to which this component belongs
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.TextMatchingStrategy.Text">
            <summary>
            Gets or sets the text that will be matched
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TextMatchFilter.TextContainsMatchingStrategy">
            <summary>
            This component provides text contains matching strategy.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextContainsMatchingStrategy.#ctor(BrightIdeasSoftware.TextMatchFilter,System.String)">
            <summary>
            Create a text contains strategy
            </summary>
            <param name="filter"></param>
            <param name="text"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextContainsMatchingStrategy.MatchesText(System.String)">
            <summary>
            Does the given text match the filter
            </summary>
            <remarks>
            <para>this.Text will not be null or empty when this is called.</para>
            </remarks>
            <param name="cellText">The text of the cell we want to search</param>
            <returns>Return true if the given cellText matches our strategy</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextContainsMatchingStrategy.FindAllMatchedRanges(System.String)">
            <summary>
            Find all the ways in which this filter matches the given string.
            </summary>
            <remarks>
            <para>
            This is used by the renderer to decide which bits of
            the string should be highlighted.
            </para>
            <para>this.Text will not be null or empty when this is called.</para>
            </remarks>
            <param name="cellText">The text of the cell we want to search</param>
            <returns>A list of character ranges indicating the matched substrings</returns>
        </member>
        <member name="T:BrightIdeasSoftware.TextMatchFilter.TextBeginsMatchingStrategy">
            <summary>
            This component provides text begins with matching strategy.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextBeginsMatchingStrategy.#ctor(BrightIdeasSoftware.TextMatchFilter,System.String)">
            <summary>
            Create a text begins strategy
            </summary>
            <param name="filter"></param>
            <param name="text"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextBeginsMatchingStrategy.MatchesText(System.String)">
            <summary>
            Does the given text match the filter
            </summary>
            <remarks>
            <para>this.Text will not be null or empty when this is called.</para>
            </remarks>
            <param name="cellText">The text of the cell we want to search</param>
            <returns>Return true if the given cellText matches our strategy</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextBeginsMatchingStrategy.FindAllMatchedRanges(System.String)">
            <summary>
            Find all the ways in which this filter matches the given string.
            </summary>
            <remarks>
            <para>
            This is used by the renderer to decide which bits of
            the string should be highlighted.
            </para>
            <para>this.Text will not be null or empty when this is called.</para>
            </remarks>
            <param name="cellText">The text of the cell we want to search</param>
            <returns>A list of character ranges indicating the matched substrings</returns>
        </member>
        <member name="T:BrightIdeasSoftware.TextMatchFilter.TextRegexMatchingStrategy">
            <summary>
            This component provides regex matching strategy.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextRegexMatchingStrategy.#ctor(BrightIdeasSoftware.TextMatchFilter,System.String)">
            <summary>
            Creates a regex strategy
            </summary>
            <param name="filter"></param>
            <param name="text"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextRegexMatchingStrategy.MatchesText(System.String)">
            <summary>
            Does the given text match the filter
            </summary>
            <remarks>
            <para>this.Text will not be null or empty when this is called.</para>
            </remarks>
            <param name="cellText">The text of the cell we want to search</param>
            <returns>Return true if the given cellText matches our strategy</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextMatchFilter.TextRegexMatchingStrategy.FindAllMatchedRanges(System.String)">
            <summary>
            Find all the ways in which this filter matches the given string.
            </summary>
            <remarks>
            <para>
            This is used by the renderer to decide which bits of
            the string should be highlighted.
            </para>
            <para>this.Text will not be null or empty when this is called.</para>
            </remarks>
            <param name="cellText">The text of the cell we want to search</param>
            <returns>A list of character ranges indicating the matched substrings</returns>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.TextRegexMatchingStrategy.RegexOptions">
            <summary>
            Gets or sets the options that will be used when compiling the regular expression.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.TextRegexMatchingStrategy.Regex">
            <summary>
            Gets or sets a compilex regular expression, based on our current Text and RegexOptions.
            </summary>
            <remarks>
            If Text fails to compile as a regular expression, this will return a Regex object
            that will match all strings.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TextMatchFilter.TextRegexMatchingStrategy.IsRegexInvalid">
            <summary>
            Gets whether or not our current regular expression is a valid regex
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AspectGetterDelegate">
            <summary>
            These delegates are used to extract an aspect from a row object
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AspectPutterDelegate">
            <summary>
            These delegates are used to put a changed value back into a model object
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AspectToStringConverterDelegate">
            <summary>
            These delegates can be used to convert an aspect value to a display string,
            instead of using the default ToString()
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CellToolTipGetterDelegate">
            <summary>
            These delegates are used to get the tooltip for a cell
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CheckStateGetterDelegate">
            <summary>
            These delegates are used to the state of the checkbox for a row object.
            </summary>
            <remarks><para>
            For reasons known only to someone in Microsoft, we can only set
            a boolean on the ListViewItem to indicate it's "checked-ness", but when
            we receive update events, we have to use a tristate CheckState. So we can
            be told about an indeterminate state, but we can't set it ourselves.
            </para>
            <para>As of version 2.0, we can now return indeterminate state.</para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.BooleanCheckStateGetterDelegate">
            <summary>
            These delegates are used to get the state of the checkbox for a row object.
            </summary>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.CheckStatePutterDelegate">
            <summary>
            These delegates are used to put a changed check state back into a model object
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.BooleanCheckStatePutterDelegate">
            <summary>
            These delegates are used to put a changed check state back into a model object
            </summary>
            <param name="rowObject"></param>
            <param name="newValue"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.ColumnRightClickEventHandler">
            <summary>
            The callbacks for RightColumnClick events
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HeaderDrawingDelegate">
            <summary>
            This delegate will be used to own draw header column.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupFormatterDelegate">
            <summary>
            This delegate is called when a group has been created but not yet made
            into a real ListViewGroup. The user can take this opportunity to fill
            in lots of other details about the group.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupKeyGetterDelegate">
            <summary>
            These delegates are used to retrieve the object that is the key of the group to which the given row belongs.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupKeyToTitleConverterDelegate">
            <summary>
            These delegates are used to convert a group key into a title for the group
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HeaderToolTipGetterDelegate">
            <summary>
            These delegates are used to get the tooltip for a column header
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ImageGetterDelegate">
            <summary>
            These delegates are used to fetch the image selector that should be used
            to choose an image for this column.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.RenderDelegate">
            <summary>
            These delegates are used to draw a cell
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.RowGetterDelegate">
            <summary>
            These delegates are used to fetch a row object for virtual lists
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.RowFormatterDelegate">
            <summary>
            These delegates are used to format a listviewitem before it is added to the control.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.SortDelegate">
            <summary>
            These delegates are used to sort the listview in some custom fashion
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupingParameters">
            <summary>
            This class contains all the settings used when groups are created
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.GroupingParameters.#ctor(BrightIdeasSoftware.ObjectListView,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,System.String,System.String,System.Boolean)">
            <summary>
            Create a GroupingParameters
            </summary>
            <param name="olv"></param>
            <param name="groupByColumn"></param>
            <param name="groupByOrder"></param>
            <param name="column"></param>
            <param name="order"></param>
            <param name="secondaryColumn"></param>
            <param name="secondaryOrder"></param>
            <param name="titleFormat"></param>
            <param name="titleSingularFormat"></param>
            <param name="sortItemsByPrimaryColumn"></param>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.ListView">
            <summary>
            Gets or sets the ObjectListView being grouped
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.GroupByColumn">
            <summary>
            Gets or sets the column used to create groups
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.GroupByOrder">
            <summary>
            In what order will the groups themselves be sorted?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.GroupComparer">
            <summary>
            If this is set, this comparer will be used to order the groups
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.ItemComparer">
            <summary>
            If this is set, this comparer will be used to order items within each group
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.PrimarySort">
            <summary>
            Gets or sets the column that will be the primary sort
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.PrimarySortOrder">
            <summary>
            Gets or sets the ordering for the primary sort
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.SecondarySort">
            <summary>
            Gets or sets the column used for secondary sorting
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.SecondarySortOrder">
            <summary>
            Gets or sets the ordering for the secondary sort
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.TitleFormat">
            <summary>
            Gets or sets the title format used for groups with zero or more than one element
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.TitleSingularFormat">
            <summary>
            Gets or sets the title format used for groups with only one element
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupingParameters.SortItemsByPrimaryColumn">
            <summary>
            Gets or sets whether the items should be sorted by the primary column
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.NullableDictionary`2">
            <summary>
            A simple-minded implementation of a Dictionary that can handle null as a key.
            </summary>
            <typeparam name="TKey">The type of the dictionary key</typeparam>
            <typeparam name="TValue">The type of the values to be stored</typeparam>
            <remarks>This is not a full implementation and is only meant to handle
            collecting groups by their keys, since groups can have null as a key value.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.OLVListItem">
            <summary>
            OLVListItems are specialized ListViewItems that know which row object they came from,
            and the row index at which they are displayed, even when in group view mode. They
            also know the image they should draw against themselves
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVListItem.#ctor(System.Object)">
            <summary>
            Create a OLVListItem for the given row object
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVListItem.#ctor(System.Object,System.String,System.Object)">
            <summary>
            Create a OLVListItem for the given row object, represented by the given string and image
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVListItem.GetSubItem(System.Int32)">
            <summary>
            Return the sub item at the given index
            </summary>
            <param name="index">Index of the subitem to be returned</param>
            <returns>An OLVListSubItem</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVListItem.GetSubItemBounds(System.Int32)">
            <summary>
            Return bounds of the given subitem
            </summary>
            <remarks>This correctly calculates the bounds even for column 0.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.Bounds">
            <summary>
            Gets the bounding rectangle of the item, including all subitems
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.CellPadding">
            <summary>
            Gets or sets how many pixels will be left blank around each cell of this item
            </summary>
            <remarks>This setting only takes effect when the control is owner drawn.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.CellVerticalAlignment">
            <summary>
            Gets or sets how the cells of this item will be vertically aligned
            </summary>
            <remarks>This setting only takes effect when the control is owner drawn.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.Checked">
            <summary>
            Gets or sets the checkedness of this item.
            </summary>
            <remarks>
            Virtual lists don't handle checkboxes well, so we have to intercept attempts to change them
            through the items, and change them into something that will work.
            Unfortuneately, this won't work if this property is set through the base class, since
            the property is not declared as virtual.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.CheckState">
            <summary>
            Enable tri-state checkbox.
            </summary>
            <remarks>.NET's Checked property was not built to handle tri-state checkboxes,
            and will return True for both Checked and Indeterminate states.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.HasDecoration">
            <summary>
            Gets if this item has any decorations set for it.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.Decoration">
            <summary>
            Gets or sets the decoration that will be drawn over this item
            </summary>
            <remarks>Setting this replaces all other decorations</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.Decorations">
            <summary>
            Gets the collection of decorations that will be drawn over this item
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.Enabled">
            <summary>
            Gets whether or not this row can be selected and activated
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.ImageSelector">
            <summary>
            Get or set the image that should be shown against this item
            </summary>
            <remarks><para>This can be an Image, a string or an int. A string or an int will
            be used as an index into the small image list.</para></remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListItem.RowObject">
            <summary>
            Gets or sets the the model object that is source of the data for this list item.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVListSubItem">
            <summary>
            A ListViewSubItem that knows which image should be drawn against it.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVListSubItem.#ctor">
            <summary>
            Create a OLVListSubItem
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVListSubItem.#ctor(System.Object,System.String,System.Object)">
            <summary>
            Create a OLVListSubItem that shows the given string and image
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OLVListSubItem.AnimationState">
            <summary>
            Return the state of the animatation of the image on this subitem.
            Null means there is either no image, or it is not an animation
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListSubItem.CellPadding">
            <summary>
            Gets or sets how many pixels will be left blank around this cell
            </summary>
            <remarks>This setting only takes effect when the control is owner drawn.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListSubItem.CellVerticalAlignment">
            <summary>
            Gets or sets how this cell will be vertically aligned
            </summary>
            <remarks>This setting only takes effect when the control is owner drawn.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListSubItem.ModelValue">
            <summary>
            Gets or sets the model value is being displayed by this subitem.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListSubItem.HasDecoration">
            <summary>
            Gets if this subitem has any decorations set for it.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListSubItem.Decoration">
            <summary>
            Gets or sets the decoration that will be drawn over this item
            </summary>
            <remarks>Setting this replaces all other decorations</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListSubItem.Decorations">
            <summary>
            Gets the collection of decorations that will be drawn over this item
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListSubItem.ImageSelector">
            <summary>
            Get or set the image that should be shown against this item
            </summary>
            <remarks><para>This can be an Image, a string or an int. A string or an int will
            be used as an index into the small image list.</para></remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVListSubItem.Url">
            <summary>
            Gets or sets the url that should be invoked when this subitem is clicked
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HitTestLocation">
            <summary>
            An indication of where a hit was within ObjectListView cell
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.Nothing">
            <summary>
            Nowhere
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.Text">
            <summary>
            On the text
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.Image">
            <summary>
            On the image
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.CheckBox">
            <summary>
            On the checkbox
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.ExpandButton">
            <summary>
            On the expand button (TreeListView)
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.InCell">
            <summary>
            in the cell but not in any more specific location
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.UserDefined">
            <summary>
            UserDefined location1 (used for custom renderers)
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.GroupExpander">
            <summary>
            On the expand/collapse widget of the group
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocation.Group">
            <summary>
            Somewhere on a group
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HitTestLocationEx">
            <summary>
            A collection of ListViewHitTest constants
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_NOWHERE">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_ONITEMICON">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_ONITEMLABEL">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_ONITEMSTATEICON">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_ONITEM">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_ABOVE">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_BELOW">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_TORIGHT">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_TOLEFT">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_GROUP_HEADER">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_GROUP_FOOTER">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_GROUP_COLLAPSE">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_GROUP_BACKGROUND">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_GROUP_STATEICON">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_GROUP_SUBSETLINK">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_GROUP">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_GROUP_MINUS_FOOTER_AND_BKGRD">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_ONCONTENTS">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.HitTestLocationEx.LVHT_EX_FOOTER">
            <summary>
            
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OlvListViewHitTestInfo">
            <summary>
            Instances of this class encapsulate the information gathered during a OlvHitTest()
            operation.
            </summary>
            <remarks>Custom renderers can use HitTestLocation.UserDefined and the UserData
            object to store more specific locations for use during event handlers.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.OlvListViewHitTestInfo.#ctor(BrightIdeasSoftware.OLVListItem,BrightIdeasSoftware.OLVListSubItem,System.Int32,BrightIdeasSoftware.OLVGroup)">
            <summary>
            Create a OlvListViewHitTestInfo
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OlvListViewHitTestInfo.HitTestLocation">
            <summary>
            Where is the hit location?
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OlvListViewHitTestInfo.HitTestLocationEx">
            <summary>
            Where is the hit location?
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OlvListViewHitTestInfo.Group">
            <summary>
            Which group was hit?
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OlvListViewHitTestInfo.UserData">
            <summary>
            Custom renderers can use this information to supply more details about the hit location
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OlvListViewHitTestInfo.ToString">
            <summary>
            Returns a string that represents the current object.
            </summary>
            <returns>
            A string that represents the current object.
            </returns>
            <filterpriority>2</filterpriority>
        </member>
        <member name="P:BrightIdeasSoftware.OlvListViewHitTestInfo.Item">
            <summary>
            Gets the item that was hit
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvListViewHitTestInfo.SubItem">
            <summary>
            Gets the subitem that was hit
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvListViewHitTestInfo.Location">
            <summary>
            Gets the part of the subitem that was hit
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvListViewHitTestInfo.ListView">
            <summary>
            Gets the ObjectListView that was tested
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvListViewHitTestInfo.RowObject">
            <summary>
            Gets the model object that was hit
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvListViewHitTestInfo.RowIndex">
            <summary>
            Gets the index of the row under the hit point or -1
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvListViewHitTestInfo.ColumnIndex">
            <summary>
            Gets the index of the column under the hit point
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvListViewHitTestInfo.Column">
            <summary>
            Gets the column that was hit
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeDataSourceAdapter">
            <summary>
            A TreeDataSourceAdapter knows how to build a tree structure from a binding list.
            </summary>
            <remarks>To build a tree</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.DataSourceAdapter">
            <summary>
            A helper class that translates DataSource events for an ObjectListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.#ctor(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Make a DataSourceAdapter
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.Finalize">
            <summary>
            Finalize this object
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.Dispose">
            <summary>
            Release all the resources used by this instance
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.Dispose(System.Boolean)">
            <summary>
            Release all the resources used by this instance
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.BindListView(BrightIdeasSoftware.ObjectListView)">
            <summary>
            
            </summary>
            <param name="olv"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.UnbindListView(BrightIdeasSoftware.ObjectListView)">
            <summary>
            
            </summary>
            <param name="olv"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.BindDataSource">
            <summary>
            
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.UnbindDataSource">
            <summary>
            
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.RebindDataSource">
            <summary>
            Our data source has changed. Figure out how to handle the new source
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.RebindDataSource(System.Boolean)">
            <summary>
            Our data source has changed. Figure out how to handle the new source
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.InitializeDataSource">
            <summary>
            The data source for this control has changed. Reconfigure the control for the new source
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.SetListContents">
            <summary>
            Take the contents of the currently bound list and put them into the control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.CreateColumnsFromSource">
            <summary>
            Create columns for the listview based on what properties are available in the data source
            </summary>
            <remarks>
            <para>This method will create columns if there is not already a column displaying that property.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.ShouldCreateColumn(System.ComponentModel.PropertyDescriptor)">
            <summary>
            Decide if a new column should be added to the control to display
            the given property
            </summary>
            <param name="property"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.ConfigureColumn(BrightIdeasSoftware.OLVColumn,System.ComponentModel.PropertyDescriptor)">
            <summary>
            Configure the given column to show the given property.
            The title and aspect name of the column are already filled in.
            </summary>
            <param name="column"></param>
            <param name="property"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.CreateMissingAspectGettersAndPutters">
            <summary>
            Generate aspect getters and putters for any columns that are missing them (and for which we have
            enough information to actually generate a getter)
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.CurrencyManagerListChanged(System.Object,System.ComponentModel.ListChangedEventArgs)">
            <summary>
            CurrencyManager ListChanged event handler.
            Deals with fine-grained changes to list items.
            </summary>
            <remarks>
            It's actually difficult to deal with these changes in a fine-grained manner.
            If our listview is grouped, then any change may make a new group appear or
            an old group disappear. It is rarely enough to simply update the affected row.
            </remarks>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListChangedMetadataChanged(System.ComponentModel.ListChangedEventArgs)">
            <summary>
            Handle PropertyDescriptor* events
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListChangedItemMoved(System.ComponentModel.ListChangedEventArgs)">
            <summary>
            Handle ItemMoved event
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListChangedItemDeleted(System.ComponentModel.ListChangedEventArgs)">
            <summary>
            Handle the ItemDeleted event
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListChangedItemAdded(System.ComponentModel.ListChangedEventArgs)">
            <summary>
            Handle an ItemAdded event.
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListChangedReset(System.ComponentModel.ListChangedEventArgs)">
            <summary>
            Handle the Reset event
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListChangedItemChanged(System.ComponentModel.ListChangedEventArgs)">
            <summary>
            Handle ItemChanged event. This is triggered when a single item
            has changed, so just refresh that one item.
            </summary>
            <param name="e"></param>
            <remarks>Even in this simple case, we should probably rebuild the list.
            For example, the change could put the item into its own new group.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleCurrencyManagerMetaDataChanged(System.Object,System.EventArgs)">
            <summary>
            The CurrencyManager calls this if the data source looks
            different. We just reload everything.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
            <remarks>
            CHECK: Do we need this if we are handle ListChanged metadata events?
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleCurrencyManagerPositionChanged(System.Object,System.EventArgs)">
            <summary>
            Called by the CurrencyManager when the currently selected item
            changes. We update the ListView selection so that we stay in sync
            with any other controls bound to the same source.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.ChangePosition(System.Int32)">
            <summary>
            Change the control's position (which is it's currently selected row)
            to the n'th row in the dataset
            </summary>
            <param name="index">The index of the row to be selected</param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListViewSelectedIndexChanged(System.Object,System.EventArgs)">
            <summary>
            Handle the selection changing in our ListView.
            We need to tell our currency manager about the new position.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListViewFreezing(System.Object,BrightIdeasSoftware.FreezeEventArgs)">
            <summary>
            Handle the frozenness of our ListView changing. 
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DataSourceAdapter.HandleListViewBindingContextChanged(System.Object,System.EventArgs)">
            <summary>
            Handle a change to the BindingContext of our ListView.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="P:BrightIdeasSoftware.DataSourceAdapter.AutoGenerateColumns">
            <summary>
            Gets or sets whether or not columns will be automatically generated to show the
            columns when the DataSource is set. 
            </summary>
            <remarks>This must be set before the DataSource is set. It has no effect afterwards.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataSourceAdapter.DataSource">
            <summary>
            Get or set the DataSource that will be displayed in this list view.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.DataSourceAdapter.DataMember">
            <summary>
            Gets or sets the name of the list or table in the data source for which the DataListView is displaying data.
            </summary>
            <remarks>If the data source is not a DataSet or DataViewManager, this property has no effect</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataSourceAdapter.ListView">
            <summary>
            Gets the ObjectListView upon which this adaptor will operate
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.DataSourceAdapter.CurrencyManager">
            <summary>
            Gets or sets the currency manager which is handling our binding context
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeDataSourceAdapter.#ctor(BrightIdeasSoftware.DataTreeListView)">
            <summary>
            Create a data source adaptor that knows how to build a tree structure
            </summary>
            <param name="tlv"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeDataSourceAdapter.InitializeDataSource">
            <summary>
            
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeDataSourceAdapter.SetListContents">
            <summary>
            
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeDataSourceAdapter.ShouldCreateColumn(System.ComponentModel.PropertyDescriptor)">
            <summary>
            
            </summary>
            <param name="property"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.TreeDataSourceAdapter.HandleListChangedItemChanged(System.ComponentModel.ListChangedEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TreeDataSourceAdapter.ChangePosition(System.Int32)">
            <summary>
            
            </summary>
            <param name="index"></param>
        </member>
        <member name="P:BrightIdeasSoftware.TreeDataSourceAdapter.KeyAspectName">
            <summary>
            Gets or sets the name of the property/column that uniquely identifies each row.
            </summary>
            <remarks>
            <para>
            The value contained by this column must be unique across all rows 
            in the data source. Odd and unpredictable things will happen if two
            rows have the same id.
            </para>
            <para>Null cannot be a valid key value.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeDataSourceAdapter.ParentKeyAspectName">
            <summary>
            Gets or sets the name of the property/column that contains the key of
            the parent of a row.
            </summary>
            <remarks>
            <para>
            The test condition for deciding if one row is the parent of another is functionally
            equivilent to this:
            <code>
            Object.Equals(candidateParentRow[this.KeyAspectName], row[this.ParentKeyAspectName])
            </code>
            </para>
            <para>Unlike key value, parent keys can be null but a null parent key can only be used
            to identify root objects.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeDataSourceAdapter.RootKeyValue">
            <summary>
            Gets or sets the value that identifies a row as a root object.
            When the ParentKey of a row equals the RootKeyValue, that row will
            be treated as root of the TreeListView.
            </summary>
            <remarks>
            <para>
            The test condition for deciding a root object is functionally
            equivilent to this:
            <code>
            Object.Equals(candidateRow[this.ParentKeyAspectName], this.RootKeyValue)
            </code>
            </para>
            <para>The RootKeyValue can be null.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeDataSourceAdapter.ShowKeyColumns">
            <summary>
            Gets or sets whether or not the key columns (id and parent id) should
            be shown to the user.
            </summary>
            <remarks>This must be set before the DataSource is set. It has no effect
            afterwards.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TreeDataSourceAdapter.TreeListView">
            <summary>
            Gets the DataTreeListView that is being managed 
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVColumn">
            <summary>
            An OLVColumn knows which aspect of an object it should present.
            </summary>
            <remarks>
            The column knows how to:
            <list type="bullet">
            <item><description>extract its aspect from the row object</description></item>
            <item><description>convert an aspect to a string</description></item>
            <item><description>calculate the image for the row object</description></item>
            <item><description>extract a group "key" from the row object</description></item>
            <item><description>convert a group "key" into a title for the group</description></item>
            </list>
            <para>For sorting to work correctly, aspects from the same column
            must be of the same type, that is, the same aspect cannot sometimes
            return strings and other times integers.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.#ctor">
            <summary>
            Create an OLVColumn
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.#ctor(System.String,System.String)">
            <summary>
            Initialize a column to have the given title, and show the given aspect
            </summary>
            <param name="title">The title of the column</param>
            <param name="aspect">The aspect to be shown in the column</param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.ConvertGroupKeyToTitle(System.Object)">
            <summary>
            For a given group value, return the string that should be used as the groups title.
            </summary>
            <param name="value">The group key that is being converted to a title</param>
            <returns>string</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.GetCheckState(System.Object)">
            <summary>
            Get the checkedness of the given object for this column
            </summary>
            <param name="rowObject">The row object that is being displayed</param>
            <returns>The checkedness of the object</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.PutCheckState(System.Object,System.Windows.Forms.CheckState)">
            <summary>
            Put the checkedness of the given object for this column
            </summary>
            <param name="rowObject">The row object that is being displayed</param>
            <param name="newState"></param>
            <returns>The checkedness of the object</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.GetAspectByName(System.Object)">
            <summary>
            For a given row object, extract the value indicated by the AspectName property of this column.
            </summary>
            <param name="rowObject">The row object that is being displayed</param>
            <returns>An object, which is the aspect named by AspectName</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.GetGroupKey(System.Object)">
            <summary>
            For a given row object, return the object that is the key of the group that this row belongs to.
            </summary>
            <param name="rowObject">The row object that is being displayed</param>
            <returns>Group key object</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.GetImage(System.Object)">
            <summary>
            For a given row object, return the image selector of the image that should displayed in this column.
            </summary>
            <param name="rowObject">The row object that is being displayed</param>
            <returns>int or string or Image. int or string will be used as index into image list. null or -1 means no image</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.GetCheckStateImage(System.Object)">
            <summary>
            Return the image that represents the check box for the given model
            </summary>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.GetStringValue(System.Object)">
            <summary>
            For a given row object, return the string representation of the value shown in this column.
            </summary>
            <remarks>
            For aspects that are string (e.g. aPerson.Name), the aspect and its string representation are the same.
            For non-strings (e.g. aPerson.DateOfBirth), the string representation is very different.
            </remarks>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.GetValue(System.Object)">
            <summary>
            For a given row object, return the object that is to be displayed in this column.
            </summary>
            <param name="rowObject">The row object that is being displayed</param>
            <returns>An object, which is the aspect to be displayed</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.PutAspectByName(System.Object,System.Object)">
            <summary>
            Update the given model object with the given value using the column's
            AspectName.
            </summary>
            <param name="rowObject">The model object to be updated</param>
            <param name="newValue">The value to be put into the model</param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.PutValue(System.Object,System.Object)">
            <summary>
            Update the given model object with the given value
            </summary>
            <param name="rowObject">The model object to be updated</param>
            <param name="newValue">The value to be put into the model</param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.ValueToString(System.Object)">
            <summary>
            Convert the aspect object to its string representation.
            </summary>
            <remarks>
            If the column has been given a AspectToStringConverter, that will be used to do
            the conversion, otherwise just use ToString(). 
            The returned value will not be null. Nulls are always converted
            to empty strings.
            </remarks>
            <param name="value">The value of the aspect that should be displayed</param>
            <returns>A string representation of the aspect</returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.DecideDefaultClusteringStrategy">
            <summary>
            Decide the clustering strategy that will be used for this column
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.MakeGroupies(System.Object[],System.String[])">
            <summary>
            Create groupies
            This is an untyped version to help with Generator and OLVColumn attributes
            </summary>
            <param name="values"></param>
            <param name="descriptions"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.MakeGroupies``1(``0[],System.String[])">
            <summary>
            Create groupies
            </summary>
            <typeparam name="T"></typeparam>
            <param name="values"></param>
            <param name="descriptions"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.MakeGroupies``1(``0[],System.String[],System.Object[])">
            <summary>
            Create groupies
            </summary>
            <typeparam name="T"></typeparam>
            <param name="values"></param>
            <param name="descriptions"></param>
            <param name="images"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.MakeGroupies``1(``0[],System.String[],System.Object[],System.String[])">
            <summary>
            Create groupies
            </summary>
            <typeparam name="T"></typeparam>
            <param name="values"></param>
            <param name="descriptions"></param>
            <param name="images"></param>
            <param name="subtitles"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.MakeGroupies``1(``0[],System.String[],System.Object[],System.String[],System.String[])">
            <summary>
            Create groupies.
            Install delegates that will group the columns aspects into progressive partitions.
            If an aspect is less than value[n], it will be grouped with description[n].
            If an aspect has a value greater than the last element in "values", it will be grouped
            with the last element in "descriptions".
            </summary>
            <param name="values">Array of values. Values must be able to be
            compared to the aspect (using IComparable)</param>
            <param name="descriptions">The description for the matching value. The last element is the default description.
            If there are n values, there must be n+1 descriptions.</param>
            <example>
            this.salaryColumn.MakeGroupies(
                new UInt32[] { 20000, 100000 },
                new string[] { "Lowly worker",  "Middle management", "Rarified elevation"});
            </example>
            <typeparam name="T"></typeparam>
            <param name="images"></param>
            <param name="subtitles"></param>
            <param name="tasks"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumn.MakeEqualGroupies``1(``0[],System.String[],System.Object[],System.String[],System.String[])">
            <summary>
            Create groupies based on exact value matches.
            </summary>
            <remarks>
            Install delegates that will group rows into partitions based on equality of this columns aspects.
            If an aspect is equal to value[n], it will be grouped with description[n].
            If an aspect is not equal to any value, it will be grouped with "[other]".
            </remarks>
            <param name="values">Array of values. Values must be able to be
            equated to the aspect</param>
            <param name="descriptions">The description for the matching value.</param>
            <example>
            this.marriedColumn.MakeEqualGroupies(
                new MaritalStatus[] { MaritalStatus.Single, MaritalStatus.Married, MaritalStatus.Divorced, MaritalStatus.Partnered },
                new string[] { "Looking",  "Content", "Looking again", "Mostly content" });
            </example>
            <typeparam name="T"></typeparam>
            <param name="images"></param>
            <param name="subtitles"></param>
            <param name="tasks"></param>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.AspectGetter">
            <summary>
            This delegate will be used to extract a value to be displayed in this column.
            </summary>
            <remarks>
            If this is set, AspectName is ignored.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.AspectGetterAutoGenerated">
            <summary>
            Remember if this aspect getter for this column was generated internally, and can therefore
            be regenerated at will
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.AspectName">
            <summary>
            The name of the property or method that should be called to get the value to display in this column.
            This is only used if a ValueGetterDelegate has not been given.
            </summary>
            <remarks>This name can be dotted to chain references to properties or parameter-less methods.</remarks>
            <example>"DateOfBirth"</example>
            <example>"Owner.HomeAddress.Postcode"</example>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.AspectPutter">
            <summary>
            This delegate will be used to put an edited value back into the model object.
            </summary>
            <remarks>
            This does nothing if IsEditable == false.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.AspectToStringConverter">
            <summary>
            The delegate that will be used to translate the aspect to display in this column into a string.
            </summary>
            <remarks>If this value is set, AspectToStringFormat will be ignored.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.AspectToStringFormat">
            <summary>
            This format string will be used to convert an aspect to its string representation.
            </summary>
            <remarks>
            This string is passed as the first parameter to the String.Format() method.
            This is only used if AspectToStringConverter has not been set.</remarks>
            <example>"{0:C}" to convert a number to currency</example>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.AutoCompleteEditor">
            <summary>
            Gets or sets whether the cell editor should use AutoComplete
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.AutoCompleteEditorMode">
            <summary>
            Gets or sets whether the cell editor should use AutoComplete
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.CanBeHidden">
            <summary>
            Gets whether this column can be hidden by user actions
            </summary>
            <remarks>This take into account both the Hideable property and whether this column
            is the primary column of the listview (column 0).</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.CellPadding">
            <summary>
            Gets or sets how many pixels will be left blank around this cells in this column
            </summary>
            <remarks>This setting only takes effect when the control is owner drawn.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.CellVerticalAlignment">
            <summary>
            Gets or sets how cells in this column will be vertically aligned.
            </summary>
            <remarks>
            <para>
            This setting only takes effect when the control is owner drawn.
            </para>        
            <para>
            If this is not set, the value from the control itself will be used.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.CheckBoxes">
            <summary>
            Gets or sets whether this column will show a checkbox.
            </summary>
            <remarks>
            Setting this on column 0 has no effect. Column 0 check box is controlled
            by the CheckBoxes property on the ObjectListView itself.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.ClusteringStrategy">
            <summary>
            Gets or sets the clustering strategy used for this column. 
            </summary>
            <remarks>
            <para>
            The clustering strategy is used to build a Filtering menu for this item. 
            If this is null, a useful default will be chosen. 
            </para>
            <para>
            To disable filtering on this colummn, set UseFiltering to false.
            </para>
            <para>
            Cluster strategies belong to a particular column. The same instance
            cannot be shared between multiple columns.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.FillsFreeSpace">
            <summary>
            Should this column resize to fill the free space in the listview?
            </summary>
            <remarks>
            <para>
            If you want two (or more) columns to equally share the available free space, set this property to True.
            If you want this column to have a larger or smaller share of the free space, you must
            set the FreeSpaceProportion property explicitly.
            </para>
            <para>
            Space filling columns are still governed by the MinimumWidth and MaximumWidth properties.
            </para>
            /// </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.FreeSpaceProportion">
            <summary>
            What proportion of the unoccupied horizontal space in the control should be given to this column?
            </summary>
            <remarks>
            <para>
            There are situations where it would be nice if a column (normally the rightmost one) would expand as
            the list view expands, so that as much of the column was visible as possible without having to scroll
            horizontally (you should never, ever make your users have to scroll anything horizontally!).
            </para>
            <para>
            A space filling column is resized to occupy a proportion of the unoccupied width of the listview (the
            unoccupied width is the width left over once all the the non-filling columns have been given their space).
            This property indicates the relative proportion of that unoccupied space that will be given to this column.
            The actual value of this property is not important -- only its value relative to the value in other columns.
            For example:
            <list type="bullet">
            <item><description>
            If there is only one space filling column, it will be given all the free space, regardless of the value in FreeSpaceProportion.
            </description></item>
            <item><description>
            If there are two or more space filling columns and they all have the same value for FreeSpaceProportion,
            they will share the free space equally.
            </description></item>
            <item><description>
            If there are three space filling columns with values of 3, 2, and 1
            for FreeSpaceProportion, then the first column with occupy half the free space, the second will
            occupy one-third of the free space, and the third column one-sixth of the free space.
            </description></item>
            </list>
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.Groupable">
            <summary>
            Gets or sets whether groups will be rebuild on this columns values when this column's header is clicked.
            </summary>
            <remarks>
            <para>This setting is only used when ShowGroups is true.</para>
            <para>
            If this is false, clicking the header will not rebuild groups. It will not provide
            any feedback as to why the list is not being regrouped. It is the programmers responsibility to
            provide appropriate feedback.
            </para>
            <para>When this is false, BeforeCreatingGroups events are still fired, which can be used to allow grouping
            or give feedback, on a case by case basis.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.GroupFormatter">
            <summary>
            This delegate is called when a group has been created but not yet made
            into a real ListViewGroup. The user can take this opportunity to fill
            in lots of other details about the group.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.GroupKeyGetter">
            <summary>
            This delegate is called to get the object that is the key for the group
            to which the given row belongs.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.GroupKeyToTitleConverter">
            <summary>
            This delegate is called to convert a group key into a title for that group.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.GroupWithItemCountFormat">
            <summary>
            When the listview is grouped by this column and group title has an item count,
            how should the lable be formatted?
            </summary>
            <remarks>
            The given format string can/should have two placeholders:
            <list type="bullet">
            <item><description>{0} - the original group title</description></item>
            <item><description>{1} - the number of items in the group</description></item>
            </list>
            </remarks>
            <example>"{0} [{1} items]"</example>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.GroupWithItemCountFormatOrDefault">
            <summary>
            Gets this.GroupWithItemCountFormat or a reasonable default
            </summary>
            <remarks>
            If GroupWithItemCountFormat is not set, its value will be taken from the ObjectListView if possible.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.GroupWithItemCountSingularFormat">
            <summary>
            When the listview is grouped by this column and a group title has an item count,
            how should the lable be formatted if there is only one item in the group?
            </summary>
            <remarks>
            The given format string can/should have two placeholders:
            <list type="bullet">
            <item><description>{0} - the original group title</description></item>
            <item><description>{1} - the number of items in the group (always 1)</description></item>
            </list>
            </remarks>
            <example>"{0} [{1} item]"</example>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.GroupWithItemCountSingularFormatOrDefault">
            <summary>
            Get this.GroupWithItemCountSingularFormat or a reasonable default
            </summary>
            <remarks>
            <para>If this value is not set, the values from the list view will be used</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HasFilterIndicator">
            <summary>
            Gets whether this column should be drawn with a filter indicator in the column header.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HeaderDrawing">
            <summary>
            Gets or sets a delegate that will be used to own draw header column.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HeaderFormatStyle">
            <summary>
            Gets or sets the style that will be used to draw the header for this column
            </summary>
            <remarks>This is only uses when the owning ObjectListView has HeaderUsesThemes set to false.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HeaderFont">
            <summary>
            Gets or sets the font in which the header for this column will be drawn
            </summary>
            <remarks>This property will be made obsolete in v2.5. Use HeaderFormatStyle instead</remarks>
            <remarks>This is only uses when HeaderUsesThemes is false.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HeaderForeColor">
            <summary>
            Gets or sets the color in which the text of the header for this column will be drawn
            </summary>
            <remarks>This property will be made obsolete in v2.5. Use HeaderFormatStyle instead</remarks>
            <remarks>This is only uses when HeaderUsesThemes is false.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HeaderImageKey">
            <summary>
            Gets or sets whether the text values in this column will act like hyperlinks
            </summary>
            <remarks>This is only taken into account when HeaderUsesThemes is false.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HeaderTextAlign">
            <summary>
            Gets or sets how the text of the header will be drawn?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HeaderTextAlignAsStringAlignment">
            <summary>
            Gets the header alignment converted to a StringAlignment
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.HasHeaderImage">
            <summary>
            Gets whether or not this column has an image in the header
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.Hideable">
            <summary>
            Gets or sets whether this column can be hidden by the user.
            </summary>
            <remarks>
            <para>Column 0 can never be hidden, regardless of this setting.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.Hyperlink">
            <summary>
            Gets or sets whether the text values in this column will act like hyperlinks
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.ImageAspectName">
            <summary>
            This is the name of property that will be invoked to get the image selector of the
            image that should be shown in this column.
            It can return an int, string, Image or null.
            </summary>
            <remarks>
            <para>This is ignored if ImageGetter is not null.</para>
            <para>The property can use these return value to identify the image:</para>
            <list type="bullet">
            <item><description>null or -1 -- indicates no image</description></item>
            <item><description>an int -- the int value will be used as an index into the image list</description></item>
            <item><description>a String -- the string value will be used as a key into the image list</description></item>
            <item><description>an Image -- the Image will be drawn directly (only in OwnerDrawn mode)</description></item>
            </list>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.ImageGetter">
            <summary>
            This delegate is called to get the image selector of the image that should be shown in this column.
            It can return an int, string, Image or null.
            </summary>
            <remarks><para>This delegate can use these return value to identify the image:</para>
            <list type="bullet">
            <item><description>null or -1 -- indicates no image</description></item>
            <item><description>an int -- the int value will be used as an index into the image list</description></item>
            <item><description>a String -- the string value will be used as a key into the image list</description></item>
            <item><description>an Image -- the Image will be drawn directly (only in OwnerDrawn mode)</description></item>
            </list>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.IsEditable">
            <summary>
            Can the values shown in this column be edited?
            </summary>
            <remarks>This defaults to true, since the primary means to control the editability of a listview
            is on the listview itself. Once a listview is editable, all the columns are too, unless the
            programmer explicitly marks them as not editable</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.IsFixedWidth">
            <summary>
            Is this column a fixed width column?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.IsTileViewColumn">
            <summary>
            Get/set whether this column should be used when the view is switched to tile view.
            </summary>
            <remarks>Column 0 is always included in tileview regardless of this setting.
            Tile views do not work well with many "columns" of information. 
            Two or three works best.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.IsHeaderVertical">
            <summary>
            Gets or sets whether the text of this header should be
            rendered vertically.
            </summary>
            <remarks>
            <para>If this is true, it is a good idea to set ToolTipText to the name of the column so it's easy to read.</para>
            <para>Currently (2010-08), vertical headers are text only. They do not draw their image.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.IsVisible">
            <summary>
            Can this column be seen by the user?
            </summary>
            <remarks>After changing this value, you must call RebuildColumns() before the changes will be effected.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.LastDisplayIndex">
            <summary>
            Where was this column last positioned within the Detail view columns
            </summary>
            <remarks>DisplayIndex is volatile. Once a column is removed from the control,
            there is no way to discover where it was in the display order. This property
            guards that information even when the column is not in the listview's active columns.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.MaximumWidth">
            <summary>
            What is the maximum width that the user can give to this column?
            </summary>
            <remarks>-1 means there is no maximum width. Give this the same value as MinimumWidth to make a fixed width column.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.MinimumWidth">
            <summary>
            What is the minimum width that the user can give to this column?
            </summary>
            <remarks>-1 means there is no minimum width. Give this the same value as MaximumWidth to make a fixed width column.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.Renderer">
            <summary>
            Get/set the renderer that will be invoked when a cell needs to be redrawn
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.RendererDelegate">
            <summary>
            This delegate is called when a cell needs to be drawn in OwnerDrawn mode.
            </summary>
            <remarks>This method is kept primarily for backwards compatibility.
            New code should implement an IRenderer, though this property will be maintained.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.Searchable">
            <summary>
            Gets or sets whether the text in this column's cell will be used when doing text searching.
            </summary>
            <remarks>
            <para>
            If this is false, text filters will not trying searching this columns cells when looking for matches.
            </para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.ShowTextInHeader">
            <summary>
            Gets or sets whether the header for this column will include the column's Text.
            </summary>
            <remarks>
            <para>
            If this is false, the only thing rendered in the column header will be the image from <see cref="P:BrightIdeasSoftware.OLVColumn.HeaderImageKey"/>.
            </para>
            <para>This setting is only considered when <see cref="P:BrightIdeasSoftware.ObjectListView.HeaderUsesThemes"/> is false on the owning ObjectListView.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.Sortable">
            <summary>
            Gets or sets whether the contents of the list will be resorted when the user clicks the 
            header of this column.
            </summary>
            <remarks>
            <para>
            If this is false, clicking the header will not sort the list, but will not provide
            any feedback as to why the list is not being sorted. It is the programmers responsibility to
            provide appropriate feedback.
            </para>
            <para>When this is false, BeforeSorting events are still fired, which can be used to allow sorting
            or give feedback, on a case by case basis.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.TextAlign">
            <summary>
            Gets or sets the horizontal alignment of the contents of the column.
            </summary>
            <remarks>.NET will not allow column 0 to have any alignment except
            to the left. We can't change the basic behaviour of the listview,
            but when owner drawn, column 0 can now have other alignments.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.TextStringAlign">
            <summary>
            Gets the StringAlignment equivilent of the column text alignment
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.ToolTipText">
            <summary>
            What string should be displayed when the mouse is hovered over the header of this column?
            </summary>
            <remarks>If a HeaderToolTipGetter is installed on the owning ObjectListView, this
            value will be ignored.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.TriStateCheckBoxes">
            <summary>
            Should this column have a tri-state checkbox?
            </summary>
            <remarks>
            If this is true, the user can choose the third state (normally Indeterminate).
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.UseInitialLetterForGroup">
            <summary>
            Group objects by the initial letter of the aspect of the column
            </summary>
            <remarks>
            One common pattern is to group column by the initial letter of the value for that group.
            The aspect must be a string (obviously).
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.UseFiltering">
            <summary>
            Gets or sets whether or not this column should be user filterable
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.ValueBasedFilter">
            <summary>
            Gets or sets a filter that will only include models where the model's value
            for this column is one of the values in ValuesChosenForFiltering
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.ValuesChosenForFiltering">
            <summary>
            Gets or sets the values that will be used to generate a filter for this
            column. For a model to be included by the generated filter, its value for this column
            must be in this list. If the list is null or empty, this column will
            not be used for filtering.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.Width">
            <summary>
            What is the width of this column?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.WordWrap">
            <summary>
            Gets or set whether the contents of this column's cells should be word wrapped
            </summary>
            <remarks>If this column uses a custom IRenderer (that is, one that is not descended
            from BaseRenderer), then that renderer is responsible for implementing word wrapping.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumn.DataType">
            <summary>
            Gets or sets the type of data shown in this column.
            </summary>
            <remarks>If this is not set, it will try to get the type
            by looking through the rows of the listview.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.Properties.Resources">
            <summary>
              A strongly-typed resource class, for looking up localized strings, etc.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.Properties.Resources.ResourceManager">
            <summary>
              Returns the cached ResourceManager instance used by this class.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.Properties.Resources.Culture">
            <summary>
              Overrides the current thread's CurrentUICulture property for all
              resource lookups using this strongly typed resource class.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GraphicAdornment">
            <summary>
            An adorment is the common base for overlays and decorations.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.GraphicAdornment.CalculateAlignedPosition(System.Drawing.Point,System.Drawing.Size,System.Drawing.ContentAlignment)">
            <summary>
            Calculate the location of rectangle of the given size,
            so that it's indicated corner would be at the given point.
            </summary>
            <param name="pt">The point</param>
            <param name="size"></param>
            <param name="corner">Which corner will be positioned at the reference point</param>
            <returns></returns>
            <example>CalculateAlignedPosition(new Point(50, 100), new Size(10, 20), System.Drawing.ContentAlignment.TopLeft) -> Point(50, 100)</example>
            <example>CalculateAlignedPosition(new Point(50, 100), new Size(10, 20), System.Drawing.ContentAlignment.MiddleCenter) -> Point(45, 90)</example>
            <example>CalculateAlignedPosition(new Point(50, 100), new Size(10, 20), System.Drawing.ContentAlignment.BottomRight) -> Point(40, 80)</example>
        </member>
        <member name="M:BrightIdeasSoftware.GraphicAdornment.CreateAlignedRectangle(System.Drawing.Rectangle,System.Drawing.Size)">
            <summary>
            Calculate a rectangle that has the given size which is positioned so that
            its alignment point is at the reference location of the given rect.
            </summary>
            <param name="r"></param>
            <param name="sz"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.GraphicAdornment.CreateAlignedRectangle(System.Drawing.Rectangle,System.Drawing.Size,System.Drawing.ContentAlignment,System.Drawing.ContentAlignment,System.Drawing.Size)">
            <summary>
            Create a rectangle of the given size which is positioned so that
            its indicated corner is at the indicated corner of the reference rect.
            </summary>
            <param name="r"></param>
            <param name="sz"></param>
            <param name="corner"></param>
            <param name="referenceCorner"></param>
            <param name="offset"></param>
            <returns></returns>
            <remarks>
            <para>Creates a rectangle so that its bottom left is at the centre of the reference:
            corner=BottomLeft, referenceCorner=MiddleCenter</para>
            <para>This is a powerful concept that takes some getting used to, but is
            very neat once you understand it.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.GraphicAdornment.CalculateCorner(System.Drawing.Rectangle,System.Drawing.ContentAlignment)">
            <summary>
            Return the point at the indicated corner of the given rectangle (it doesn't
            have to be a corner, but a named location)
            </summary>
            <param name="r">The reference rectangle</param>
            <param name="corner">Which point of the rectangle should be returned?</param>
            <returns>A point</returns>
            <example>CalculateReferenceLocation(new Rectangle(0, 0, 50, 100), System.Drawing.ContentAlignment.TopLeft) -> Point(0, 0)</example>
            <example>CalculateReferenceLocation(new Rectangle(0, 0, 50, 100), System.Drawing.ContentAlignment.MiddleCenter) -> Point(25, 50)</example>
            <example>CalculateReferenceLocation(new Rectangle(0, 0, 50, 100), System.Drawing.ContentAlignment.BottomRight) -> Point(50, 100)</example>
        </member>
        <member name="M:BrightIdeasSoftware.GraphicAdornment.CalculateItemBounds(BrightIdeasSoftware.OLVListItem,BrightIdeasSoftware.OLVListSubItem)">
            <summary>
            Given the item and the subitem, calculate its bounds.
            </summary>
            <param name="item"></param>
            <param name="subItem"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.GraphicAdornment.ApplyRotation(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Apply any specified rotation to the Graphic content.
            </summary>
            <param name="g">The Graphics to be transformed</param>
            <param name="r">The rotation will be around the centre of this rect</param>
        </member>
        <member name="M:BrightIdeasSoftware.GraphicAdornment.UnapplyRotation(System.Drawing.Graphics)">
            <summary>
            Reverse the rotation created by ApplyRotation()
            </summary>
            <param name="g"></param>
        </member>
        <member name="P:BrightIdeasSoftware.GraphicAdornment.AdornmentCorner">
            <summary>
            Gets or sets the corner of the adornment that will be positioned at the reference corner
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GraphicAdornment.Alignment">
            <summary>
            Gets or sets location within the reference rectange where the adornment will be drawn
            </summary>
            <remarks>This is a simplied interface to ReferenceCorner and AdornmentCorner </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.GraphicAdornment.Offset">
            <summary>
            Gets or sets the offset by which the position of the adornment will be adjusted
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GraphicAdornment.ReferenceCorner">
            <summary>
            Gets or sets the point of the reference rectangle to which the adornment will be aligned.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GraphicAdornment.Rotation">
            <summary>
            Gets or sets the degree of rotation by which the adornment will be transformed.
            The centre of rotation will be the center point of the adornment.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GraphicAdornment.Transparency">
            <summary>
            Gets or sets the transparency of the overlay. 
            0 is completely transparent, 255 is completely opaque.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ImageAdornment">
            <summary>
            An overlay that will draw an image over the top of the ObjectListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageAdornment.DrawImage(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the image in its specified location
            </summary>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageAdornment.DrawImage(System.Drawing.Graphics,System.Drawing.Rectangle,System.Drawing.Image,System.Int32)">
            <summary>
            Draw the image in its specified location
            </summary>
            <param name="image">The image to be drawn</param>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
            <param name="transparency">How transparent should the image be (0 is completely transparent, 255 is opaque)</param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageAdornment.DrawImage(System.Drawing.Graphics,System.Drawing.Rectangle,System.Drawing.Image,System.Drawing.Size,System.Int32)">
            <summary>
            Draw the image in its specified location
            </summary>
            <param name="image">The image to be drawn</param>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
            <param name="sz">How big should the image be?</param>
            <param name="transparency">How transparent should the image be (0 is completely transparent, 255 is opaque)</param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageAdornment.DrawScaledImage(System.Drawing.Graphics,System.Drawing.Rectangle,System.Drawing.Image,System.Int32)">
            <summary>
            Draw the image in its specified location, scaled so that it is not wider
            than the given rectangle. Height is scaled proportional to the width.
            </summary>
            <param name="image">The image to be drawn</param>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
            <param name="transparency">How transparent should the image be (0 is completely transparent, 255 is opaque)</param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageAdornment.DrawTransparentBitmap(System.Drawing.Graphics,System.Drawing.Rectangle,System.Drawing.Image,System.Int32)">
            <summary>
            Utility to draw a bitmap transparenly.
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="image"></param>
            <param name="transparency"></param>
        </member>
        <member name="P:BrightIdeasSoftware.ImageAdornment.Image">
            <summary>
            Gets or sets the image that will be drawn
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ImageAdornment.ShrinkToWidth">
            <summary>
            Gets or sets if the image will be shrunk to fit with its horizontal bounds
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TextAdornment">
            <summary>
            An adornment that will draw text
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextAdornment.DrawText(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our text with our stored configuration in relation to the given
            reference rectangle
            </summary>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The reference rectangle in relation to which the text will be drawn</param>
        </member>
        <member name="M:BrightIdeasSoftware.TextAdornment.DrawText(System.Drawing.Graphics,System.Drawing.Rectangle,System.String,System.Int32)">
            <summary>
            Draw the given text with our stored configuration
            </summary>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The reference rectangle in relation to which the text will be drawn</param>
            <param name="s">The text to draw</param>
            <param name="transparency">How opaque should be text be</param>
        </member>
        <member name="M:BrightIdeasSoftware.TextAdornment.DrawBorderedText(System.Drawing.Graphics,System.Drawing.Rectangle,System.String,System.Int32)">
            <summary>
            Draw the text with a border
            </summary>
            <param name="g">The Graphics used for drawing</param>
            <param name="textRect">The bounds within which the text should be drawn</param>
            <param name="text">The text to draw</param>
            <param name="transparency">How opaque should be text be</param>
        </member>
        <member name="M:BrightIdeasSoftware.TextAdornment.CalculateTextBounds(System.Drawing.Graphics,System.Drawing.Rectangle,System.String)">
            <summary>
            Return the rectangle that will be the precise bounds of the displayed text
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="s"></param>
            <returns>The bounds of the text</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TextAdornment.GetRoundedRect(System.Drawing.Rectangle,System.Single)">
            <summary>
            Return a GraphicPath that is a round cornered rectangle
            </summary>
            <param name="rect">The rectangle</param>
            <param name="diameter">The diameter of the corners</param>
            <returns>A round cornered rectagle path</returns>
            <remarks>If I could rely on people using C# 3.0+, this should be
            an extension method of GraphicsPath.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.BackColor">
            <summary>
            Gets or sets the background color of the text
            Set this to Color.Empty to not draw a background
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.BackgroundBrush">
            <summary>
            Gets the brush that will be used to paint the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.BorderColor">
            <summary>
            Gets or sets the color of the border around the billboard.
            Set this to Color.Empty to remove the border
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.BorderPen">
            <summary>
            Gets the brush that will be used to paint the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.BorderWidth">
            <summary>
            Gets or sets the width of the border around the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.CornerRounding">
            <summary>
            How rounded should the corners of the border be? 0 means no rounding.
            </summary>
            <remarks>If this value is too large, the edges of the border will appear odd.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.Font">
            <summary>
            Gets or sets the font that will be used to draw the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.FontOrDefault">
            <summary>
            Gets the font that will be used to draw the text or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.HasBackground">
            <summary>
            Does this text have a background?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.HasBorder">
            <summary>
            Does this overlay have a border?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.MaximumTextWidth">
            <summary>
            Gets or sets the maximum width of the text. Text longer than this will wrap.
            0 means no maximum.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.StringFormat">
            <summary>
            Gets or sets the formatting that should be used on the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.Text">
            <summary>
            Gets or sets the text that will be drawn
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.TextBrush">
            <summary>
            Gets the brush that will be used to paint the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.TextColor">
            <summary>
            Gets or sets the color of the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextAdornment.Wrap">
            <summary>
            Gets or sets whether the text will wrap when it exceeds its bounds
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVColumnAttribute">
            <summary>
            This attribute is used to mark a property of a model
            class that should be noticed by Generator class.
            </summary>
            <remarks>
            All the attributes of this class match their equivilent properties on OLVColumn.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumnAttribute.#ctor">
            <summary>
            Create a new OLVColumnAttribute
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVColumnAttribute.#ctor(System.String)">
            <summary>
            Create a new OLVColumnAttribute with the given title
            </summary>
            <param name="title">The title of the column</param>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.AspectToStringFormat">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.CheckBoxes">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.DisplayIndex">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.FillsFreeSpace">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.FreeSpaceProportion">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.GroupCutoffs">
            <summary>
            An array of IComparables that mark the cutoff points for values when
            grouping on this column. 
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.GroupDescriptions">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.GroupWithItemCountFormat">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.GroupWithItemCountSingularFormat">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.Hyperlink">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.ImageAspectName">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.IsEditable">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.IsVisible">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.IsTileViewColumn">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.MaximumWidth">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.MinimumWidth">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.Name">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.TextAlign">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.Tag">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.Title">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.ToolTipText">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.TriStateCheckBoxes">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.UseInitialLetterForGroup">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVColumnAttribute.Width">
            <summary>
            
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVChildrenAttribute">
            <summary>
            Properties marked with [OLVChildren] will be used as the children source in a TreeListView.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVIgnoreAttribute">
            <summary>
            Properties marked with [OLVIgnore] will not have columns generated for them.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ComboBoxItem">
            <summary>
            These items allow combo boxes to remember a value and its description.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ComboBoxItem.#ctor(System.Object,System.String)">
            <summary>
            
            </summary>
            <param name="key"></param>
            <param name="description"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ComboBoxItem.ToString">
            <summary>
            Returns a string that represents the current object.
            </summary>
            <returns>
            A string that represents the current object.
            </returns>
            <filterpriority>2</filterpriority>
        </member>
        <member name="P:BrightIdeasSoftware.ComboBoxItem.Key">
            <summary>
            
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AutoCompleteCellEditor">
            <summary>
            This editor shows and auto completes values from the given listview column.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AutoCompleteCellEditor.#ctor(BrightIdeasSoftware.ObjectListView,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Create an AutoCompleteCellEditor
            </summary>
            <param name="lv"></param>
            <param name="column"></param>
        </member>
        <member name="T:BrightIdeasSoftware.EnumCellEditor">
            <summary>
            This combo box is specialised to allow editing of an enum.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.EnumCellEditor.#ctor(System.Type)">
            <summary>
            
            </summary>
            <param name="type"></param>
        </member>
        <member name="T:BrightIdeasSoftware.IntUpDown">
            <summary>
            This editor simply shows and edits integer values.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IntUpDown.#ctor">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IntUpDown.Value">
            <summary>
            Gets or sets the value shown by this editor
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.UintUpDown">
            <summary>
            This editor simply shows and edits unsigned integer values.
            </summary>
            <remarks>This class can't be made public because unsigned int is not a
            CLS-compliant type. If you want to use, just copy the code to this class
            into your project and use it from there.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.BooleanCellEditor">
            <summary>
            This editor simply shows and edits boolean values.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BooleanCellEditor.#ctor">
            <summary>
            
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.BooleanCellEditor2">
            <summary>
            This editor simply shows and edits boolean values using a checkbox
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BooleanCellEditor2.Value">
            <summary>
            Gets or sets the value shown by this editor
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BooleanCellEditor2.TextAlign">
            <summary>
            Gets or sets how the checkbox will be aligned
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FloatCellEditor">
            <summary>
            This editor simply shows and edits floating point values.
            </summary>
            <remarks>You can intercept the CellEditStarting event if you want
            to change the characteristics of the editor. For example, by increasing
            the number of decimal places.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.FloatCellEditor.#ctor">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FloatCellEditor.Value">
            <summary>
            Gets or sets the value shown by this editor
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.EditorCreatorDelegate">
            <summary>
            A delegate that creates an editor for the given value
            </summary>
            <param name="model">The model from which that value came</param>
            <param name="column">The column for which the editor is being created</param>
            <param name="value">A representative value of the type to be edited. This value may not be the exact
            value for the column/model combination. It could be simply representative of
            the appropriate type of value.</param>
            <returns>A control which can edit the given value</returns>
        </member>
        <member name="T:BrightIdeasSoftware.EditorRegistry">
            <summary>
            An editor registry gives a way to decide what cell editor should be used to edit
            the value of a cell. Programmers can register non-standard types and the control that 
            should be used to edit instances of that type. 
            </summary>
            <remarks>
            <para>All ObjectListViews share the same editor registry.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.EditorRegistry.#ctor">
            <summary>
            Create an EditorRegistry
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.EditorRegistry.Register(System.Type,System.Type)">
            <summary>
            Register that values of 'type' should be edited by instances of 'controlType'.
            </summary>
            <param name="type">The type of value to be edited</param>
            <param name="controlType">The type of the Control that will edit values of 'type'</param>
            <example>
            ObjectListView.EditorRegistry.Register(typeof(Color), typeof(MySpecialColorEditor));
            </example>
        </member>
        <member name="M:BrightIdeasSoftware.EditorRegistry.Register(System.Type,BrightIdeasSoftware.EditorCreatorDelegate)">
            <summary>
            Register the given delegate so that it is called to create editors
            for values of the given type
            </summary>
            <param name="type">The type of value to be edited</param>
            <param name="creator">The delegate that will create a control that can edit values of 'type'</param>
            <example>
            ObjectListView.EditorRegistry.Register(typeof(Color), CreateColorEditor);
            ...
            public Control CreateColorEditor(Object model, OLVColumn column, Object value)
            {
                return new MySpecialColorEditor();
            }
            </example>
        </member>
        <member name="M:BrightIdeasSoftware.EditorRegistry.RegisterDefault(BrightIdeasSoftware.EditorCreatorDelegate)">
            <summary>
            Register a delegate that will be called to create an editor for values
            that have not been handled.
            </summary>
            <param name="creator">The delegate that will create a editor for all other types</param>
        </member>
        <member name="M:BrightIdeasSoftware.EditorRegistry.RegisterFirstChance(BrightIdeasSoftware.EditorCreatorDelegate)">
            <summary>
            Register a delegate that will be given a chance to create a control
            before any other option is considered.
            </summary>
            <param name="creator">The delegate that will create a control</param>
        </member>
        <member name="M:BrightIdeasSoftware.EditorRegistry.GetEditor(System.Object,BrightIdeasSoftware.OLVColumn,System.Object)">
            <summary>
            Create and return an editor that is appropriate for the given value.
            Return null if no appropriate editor can be found.
            </summary>
            <param name="model">The model involved</param>
            <param name="column">The column to be edited</param>
            <param name="value">The value to be edited. This value may not be the exact
            value for the column/model combination. It could be simply representative of
            the appropriate type of value.</param>
            <returns>A Control that can edit the given type of values</returns>
        </member>
        <member name="M:BrightIdeasSoftware.EditorRegistry.CreateEnumEditor(System.Type)">
            <summary>
            Create and return an editor that will edit values of the given type
            </summary>
            <param name="type">A enum type</param>
        </member>
        <member name="T:BrightIdeasSoftware.DataListView">
            <summary>
            A DataListView is a ListView that can be bound to a datasource (which would normally be a DataTable or DataView).
            </summary>
            <remarks>
            <para>This listview keeps itself in sync with its source datatable by listening for change events.</para>
            <para>The DataListView will automatically create columns to show all of the data source's columns/properties, if there is not already
            a column showing that property. This allows you to define one or two columns in the designer and then have the others generated automatically.
            If you don't want any column to be auto generated, set <see cref="P:BrightIdeasSoftware.DataListView.AutoGenerateColumns"/> to false.
            These generated columns will be only the simplest view of the world, and would look more interesting with a few delegates installed.</para>
            <para>This listview will also automatically generate missing aspect getters to fetch the values from the data view.</para>
            <para>Changing data sources is possible, but error prone. Before changing data sources, the programmer is responsible for modifying/resetting
            the column collection to be valid for the new data source.</para>
            <para>Internally, a CurrencyManager controls keeping the data source in-sync with other users of the data source (as per normal .NET
            behavior). This means that the model objects in the DataListView are DataRowView objects. If you write your own AspectGetters/Setters,
            they will be given DataRowView objects.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.DataListView.#ctor">
            <summary>
            Make a DataListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DataListView.AddObjects(System.Collections.ICollection)">
            <summary>
            Add the given collection of model objects to this control.
            </summary>
            <param name="modelObjects">A collection of model objects</param>
            <remarks>This is a no-op for data lists, since the data
            is controlled by the VirtualListDataSource. Manipulate the data source
            rather than this view of the data source.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.DataListView.RemoveObjects(System.Collections.ICollection)">
            <summary>
            Remove the given collection of model objects from this control.
            </summary>
            <remarks>This is a no-op for data lists, since the data
            is controlled by the VirtualListDataSource. Manipulate the data source
            rather than this view of the data source.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.DataListView.OnParentBindingContextChanged(System.EventArgs)">
            <summary>
            Handles parent binding context changes
            </summary>
            <param name="e">Unused EventArgs.</param>
        </member>
        <member name="P:BrightIdeasSoftware.DataListView.AutoGenerateColumns">
            <summary>
            Gets or sets whether or not columns will be automatically generated to show the
            columns when the DataSource is set. 
            </summary>
            <remarks>This must be set before the DataSource is set. It has no effect afterwards.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataListView.DataSource">
            <summary>
            Get or set the DataSource that will be displayed in this list view.
            </summary>
            <remarks>The DataSource should implement either <see cref="T:System.Collections.IList"/>, <see cref="T:System.ComponentModel.IBindingList"/>,
            or <see cref="T:System.ComponentModel.IListSource"/>. Some common examples are the following types of objects:
            <list type="unordered">
            <item><description><see cref="T:System.Data.DataView"/></description></item>
            <item><description><see cref="T:System.Data.DataTable"/></description></item>
            <item><description><see cref="T:System.Data.DataSet"/></description></item>
            <item><description><see cref="T:System.Data.DataViewManager"/></description></item>
            <item><description><see cref="T:System.Windows.Forms.BindingSource"/></description></item>
            </list>
            <para>When binding to a list container (i.e. one that implements the
            <see cref="T:System.ComponentModel.IListSource"/> interface, such as <see cref="T:System.Data.DataSet"/>)
            you must also set the <see cref="P:BrightIdeasSoftware.DataListView.DataMember"/> property in order
            to identify which particular list you would like to display. You
            may also set the <see cref="P:BrightIdeasSoftware.DataListView.DataMember"/> property even when
            DataSource refers to a list, since <see cref="P:BrightIdeasSoftware.DataListView.DataMember"/> can
            also be used to navigate relations between lists.</para>
            <para>When a DataSource is set, the control will create OLVColumns to show any
            data source columns that are not already shown.</para>
            <para>If the DataSource is changed, you will have to remove any previously
            created columns, since they will be configured for the previous DataSource.
            <see cref="M:BrightIdeasSoftware.ObjectListView.Reset"/>.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataListView.DataMember">
            <summary>
            Gets or sets the name of the list or table in the data source for which the DataListView is displaying data.
            </summary>
            <remarks>If the data source is not a DataSet or DataViewManager, this property has no effect</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DataListView.Adapter">
            <summary>
            Gets or sets the DataSourceAdaptor that does the bulk of the work needed
            for data binding.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IDecoration">
            <summary>
            A decoration is an overlay that draws itself in relation to a given row or cell.
            Decorations scroll when the listview scrolls.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IOverlay">
            <summary>
            The interface for an object which can draw itself over the top of
            an ObjectListView.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IOverlay.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw this overlay
            </summary>
            <param name="olv">The ObjectListView that is being overlaid</param>
            <param name="g">The Graphics onto the given OLV</param>
            <param name="r">The content area of the OLV</param>
        </member>
        <member name="P:BrightIdeasSoftware.IDecoration.ListItem">
            <summary>
            Gets or sets the row that is to be decorated
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IDecoration.SubItem">
            <summary>
            Gets or sets the subitem that is to be decorated
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractDecoration">
            <summary>
            An AbstractDecoration is a safe do-nothing implementation of the IDecoration interface
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDecoration.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the decoration
            </summary>
            <param name="olv"></param>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="P:BrightIdeasSoftware.AbstractDecoration.ListItem">
            <summary>
            Gets or sets the row that is to be decorated
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AbstractDecoration.SubItem">
            <summary>
            Gets or sets the subitem that is to be decorated
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AbstractDecoration.RowBounds">
            <summary>
            Gets the bounds of the decorations row
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AbstractDecoration.CellBounds">
            <summary>
            Get the bounds of the decorations cell
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TintedColumnDecoration">
            <summary>
            This decoration draws a slight tint over a column of the
            owning listview. If no column is explicitly set, the selected
            column in the listview will be used.
            The selected column is normally the sort column, but does not have to be.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TintedColumnDecoration.#ctor">
            <summary>
            Create a TintedColumnDecoration
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TintedColumnDecoration.#ctor(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Create a TintedColumnDecoration
            </summary>
            <param name="column"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TintedColumnDecoration.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw a slight colouring over our tinted column
            </summary>
            <remarks>
            This overlay only works when:
            - the list is in Details view
            - there is at least one row
            - there is a selected column (or a specified tint column)
            </remarks>
            <param name="olv"></param>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="P:BrightIdeasSoftware.TintedColumnDecoration.ColumnToTint">
            <summary>
            Gets or sets the column that will be tinted
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TintedColumnDecoration.Tint">
            <summary>
            Gets or sets the color that will be 'tinted' over the selected column
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.BorderDecoration">
            <summary>
            This decoration draws an optionally filled border around a rectangle.
            Subclasses must override CalculateBounds().
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BorderDecoration.#ctor">
            <summary>
            Create a BorderDecoration
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BorderDecoration.#ctor(System.Drawing.Pen)">
            <summary>
            Create a BorderDecoration
            </summary>
            <param name="borderPen">The pen used to draw the border</param>
        </member>
        <member name="M:BrightIdeasSoftware.BorderDecoration.#ctor(System.Drawing.Pen,System.Drawing.Brush)">
            <summary>
            Create a BorderDecoration
            </summary>
            <param name="borderPen">The pen used to draw the border</param>
            <param name="fill">The brush used to fill the rectangle</param>
        </member>
        <member name="M:BrightIdeasSoftware.BorderDecoration.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw a filled border 
            </summary>
            <param name="olv"></param>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BorderDecoration.CalculateBounds">
            <summary>
            Subclasses should override this to say where the border should be drawn
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.BorderDecoration.DrawFilledBorder(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Do the actual work of drawing the filled border
            </summary>
            <param name="g"></param>
            <param name="bounds"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BorderDecoration.GetRoundedRect(System.Drawing.RectangleF,System.Single)">
            <summary>
            Create a GraphicsPath that represents a round cornered rectangle.
            </summary>
            <param name="rect"></param>
            <param name="diameter">If this is 0 or less, the rectangle will not be rounded.</param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.BorderDecoration.BorderPen">
            <summary>
            Gets or sets the pen that will be used to draw the border
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BorderDecoration.BoundsPadding">
            <summary>
            Gets or sets the padding that will be added to the bounds of the item
            before drawing the border and fill.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BorderDecoration.CornerRounding">
            <summary>
            How rounded should the corners of the border be? 0 means no rounding.
            </summary>
            <remarks>If this value is too large, the edges of the border will appear odd.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BorderDecoration.FillBrush">
            <summary>
            Gets or sets the brush that will be used to fill the border
            </summary>
            <remarks>This value is ignored when using gradient brush</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BorderDecoration.FillGradientFrom">
            <summary>
            Gets or sets the color that will be used as the start of a gradient fill.
            </summary>
            <remarks>This and FillGradientTo must be given value to show a gradient</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BorderDecoration.FillGradientTo">
            <summary>
            Gets or sets the color that will be used as the end of a gradient fill.
            </summary>
            <remarks>This and FillGradientFrom must be given value to show a gradient</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BorderDecoration.FillGradientMode">
            <summary>
            Gets or sets the fill mode that will be used for the gradient.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.RowBorderDecoration">
            <summary>
            Instances of this class draw a border around the decorated row
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.RowBorderDecoration.CalculateBounds">
            <summary>
            Calculate the boundaries of the border
            </summary>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.RowBorderDecoration.LeftColumn">
            <summary>
            Gets or sets the index of the left most column to be used for the border
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.RowBorderDecoration.RightColumn">
            <summary>
            Gets or sets the index of the right most column to be used for the border
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CellBorderDecoration">
            <summary>
            Instances of this class draw a border around the decorated subitem.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CellBorderDecoration.CalculateBounds">
            <summary>
            Calculate the boundaries of the border
            </summary>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.EditingCellBorderDecoration">
            <summary>
            This decoration puts a border around the cell being edited and
            optionally "lightboxes" the cell (makes the rest of the control dark).
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.EditingCellBorderDecoration.#ctor">
            <summary>
            Create a EditingCellBorderDecoration
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.EditingCellBorderDecoration.#ctor(System.Boolean)">
            <summary>
            Create a EditingCellBorderDecoration
            </summary>
            <param name="useLightBox">Should the decoration use a lighbox display style?</param>
        </member>
        <member name="M:BrightIdeasSoftware.EditingCellBorderDecoration.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the decoration
            </summary>
            <param name="olv"></param>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="P:BrightIdeasSoftware.EditingCellBorderDecoration.UseLightbox">
            <summary>
            Gets or set whether the decoration should make the rest of
            the control dark when a cell is being edited
            </summary>
            <remarks>If this is true, FillBrush is used to overpaint
            the control.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.LightBoxDecoration">
            <summary>
            This decoration causes everything *except* the row under the mouse to be overpainted
            with a tint, making the row under the mouse stand out in comparison.
            The darker and more opaque the fill color, the more obvious the
            decorated row becomes.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.LightBoxDecoration.#ctor">
            <summary>
            Create a LightBoxDecoration
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.LightBoxDecoration.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw a tint over everything in the ObjectListView except the 
            row under the mouse.
            </summary>
            <param name="olv"></param>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="T:BrightIdeasSoftware.ImageDecoration">
            <summary>
            Instances of this class put an Image over the row/cell that it is decorating
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageDecoration.#ctor">
            <summary>
            Create an image decoration
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageDecoration.#ctor(System.Drawing.Image)">
            <summary>
            Create an image decoration
            </summary>
            <param name="image"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageDecoration.#ctor(System.Drawing.Image,System.Int32)">
            <summary>
            Create an image decoration
            </summary>
            <param name="image"></param>
            <param name="transparency"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageDecoration.#ctor(System.Drawing.Image,System.Drawing.ContentAlignment)">
            <summary>
            Create an image decoration
            </summary>
            <param name="image"></param>
            <param name="alignment"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageDecoration.#ctor(System.Drawing.Image,System.Int32,System.Drawing.ContentAlignment)">
            <summary>
            Create an image decoration
            </summary>
            <param name="image"></param>
            <param name="transparency"></param>
            <param name="alignment"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageDecoration.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw this decoration
            </summary>
            <param name="olv">The ObjectListView being decorated</param>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
        </member>
        <member name="P:BrightIdeasSoftware.ImageDecoration.ListItem">
            <summary>
            Gets or sets the item being decorated
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ImageDecoration.SubItem">
            <summary>
            Gets or sets the sub item being decorated
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TextDecoration">
            <summary>
            Instances of this class draw some text over the row/cell that they are decorating
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextDecoration.#ctor">
            <summary>
            Create a TextDecoration
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextDecoration.#ctor(System.String)">
            <summary>
            Create a TextDecoration
            </summary>
            <param name="text"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextDecoration.#ctor(System.String,System.Int32)">
            <summary>
            Create a TextDecoration
            </summary>
            <param name="text"></param>
            <param name="transparency"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextDecoration.#ctor(System.String,System.Drawing.ContentAlignment)">
            <summary>
            Create a TextDecoration
            </summary>
            <param name="text"></param>
            <param name="alignment"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextDecoration.#ctor(System.String,System.Int32,System.Drawing.ContentAlignment)">
            <summary>
            Create a TextDecoration
            </summary>
            <param name="text"></param>
            <param name="transparency"></param>
            <param name="alignment"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TextDecoration.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw this decoration
            </summary>
            <param name="olv">The ObjectListView being decorated</param>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
        </member>
        <member name="P:BrightIdeasSoftware.TextDecoration.ListItem">
            <summary>
            Gets or sets the item being decorated
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextDecoration.SubItem">
            <summary>
            Gets or sets the sub item being decorated
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IDragSource">
            <summary>
            An IDragSource controls how drag out from the ObjectListView will behave
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IDragSource.StartDrag(BrightIdeasSoftware.ObjectListView,System.Windows.Forms.MouseButtons,BrightIdeasSoftware.OLVListItem)">
            <summary>
            A drag operation is beginning. Return the data object that will be used 
            for data transfer. Return null to prevent the drag from starting. The data
            object will normally include all the selected objects.
            </summary>
            <remarks>
            The returned object is later passed to the GetAllowedEffect() and EndDrag()
            methods.
            </remarks>
            <param name="olv">What ObjectListView is being dragged from.</param>
            <param name="button">Which mouse button is down?</param>
            <param name="item">What item was directly dragged by the user? There may be more than just this 
            item selected.</param>
            <returns>The data object that will be used for data transfer. This will often be a subclass
            of DataObject, but does not need to be.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.IDragSource.GetAllowedEffects(System.Object)">
            <summary>
            What operations are possible for this drag? This controls the icon shown during the drag
            </summary>
            <param name="dragObject">The data object returned by StartDrag()</param>
            <returns>A combination of DragDropEffects flags</returns>
        </member>
        <member name="M:BrightIdeasSoftware.IDragSource.EndDrag(System.Object,System.Windows.Forms.DragDropEffects)">
            <summary>
            The drag operation is complete. Do whatever is necessary to complete the action.
            </summary>
            <param name="dragObject">The data object returned by StartDrag()</param>
            <param name="effect">The value returned from GetAllowedEffects()</param>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractDragSource">
            <summary>
            A do-nothing implementation of IDragSource that can be safely subclassed.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDragSource.StartDrag(BrightIdeasSoftware.ObjectListView,System.Windows.Forms.MouseButtons,BrightIdeasSoftware.OLVListItem)">
            <summary>
            See IDragSource documentation
            </summary>
            <param name="olv"></param>
            <param name="button"></param>
            <param name="item"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDragSource.GetAllowedEffects(System.Object)">
            <summary>
            See IDragSource documentation
            </summary>
            <param name="data"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDragSource.EndDrag(System.Object,System.Windows.Forms.DragDropEffects)">
            <summary>
            See IDragSource documentation
            </summary>
            <param name="dragObject"></param>
            <param name="effect"></param>
        </member>
        <member name="T:BrightIdeasSoftware.SimpleDragSource">
            <summary>
            A reasonable implementation of IDragSource that provides normal
            drag source functionality. It creates a data object that supports
            inter-application dragging of text and HTML representation of 
            the dragged rows. It can optionally force a refresh of all dragged
            rows when the drag is complete.
            </summary>
            <remarks>Subclasses can override GetDataObject() to add new
            data formats to the data transfer object.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDragSource.#ctor">
            <summary>
            Construct a SimpleDragSource
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDragSource.#ctor(System.Boolean)">
            <summary>
            Construct a SimpleDragSource that refreshes the dragged rows when
            the drag is complete
            </summary>
            <param name="refreshAfterDrop"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDragSource.StartDrag(BrightIdeasSoftware.ObjectListView,System.Windows.Forms.MouseButtons,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Create a DataObject when the user does a left mouse drag operation.
            See IDragSource for further information.
            </summary>
            <param name="olv"></param>
            <param name="button"></param>
            <param name="item"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDragSource.GetAllowedEffects(System.Object)">
            <summary>
            Which operations are allowed in the operation? By default, all operations are supported.
            </summary>
            <param name="data"></param>
            <returns>All opertions are supported</returns>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDragSource.EndDrag(System.Object,System.Windows.Forms.DragDropEffects)">
            <summary>
            The drag operation is finished. Refreshe the dragged rows if so configured.
            </summary>
            <param name="dragObject"></param>
            <param name="effect"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDragSource.CreateDataObject(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Create a data object that will be used to as the data object
            for the drag operation.
            </summary>
            <remarks>
            Subclasses can override this method add new formats to the data object.
            </remarks>
            <param name="olv">The ObjectListView that is the source of the drag</param>
            <returns>A data object for the drag</returns>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDragSource.RefreshAfterDrop">
            <summary>
            Gets or sets whether the dragged rows should be refreshed when the 
            drag operation is complete.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IDropSink">
            <summary>
            Objects that implement this interface can acts as the receiver for drop
            operation for an ObjectListView.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IDropSink.DrawFeedback(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw any feedback that is appropriate to the current drop state.
            </summary>
            <remarks>
            Any drawing is done over the top of the ListView. This operation should disturb
            the Graphic as little as possible. Specifically, do not erase the area into which
            you draw. 
            </remarks>
            <param name="g">A Graphic for drawing</param>
            <param name="bounds">The contents bounds of the ListView (not including any header)</param>
        </member>
        <member name="M:BrightIdeasSoftware.IDropSink.Drop(System.Windows.Forms.DragEventArgs)">
            <summary>
            The user has released the drop over this control
            </summary>
            <remarks>
            Implementators should set args.Effect to the appropriate DragDropEffects. This value is returned
            to the originator of the drag.
            </remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IDropSink.Enter(System.Windows.Forms.DragEventArgs)">
            <summary>
            A drag has entered this control.
            </summary>
            <remarks>Implementators should set args.Effect to the appropriate DragDropEffects.</remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IDropSink.GiveFeedback(System.Windows.Forms.GiveFeedbackEventArgs)">
            <summary>
            Change the cursor to reflect the current drag operation.
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IDropSink.Leave">
            <summary>
            The drag has left the bounds of this control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IDropSink.Over(System.Windows.Forms.DragEventArgs)">
            <summary>
            The drag is moving over this control.
            </summary>
            <remarks>This is where any drop target should be calculated.
            Implementators should set args.Effect to the appropriate DragDropEffects.
            </remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IDropSink.QueryContinue(System.Windows.Forms.QueryContinueDragEventArgs)">
            <summary>
            Should the drag be allowed to continue?
            </summary>
            <param name="args"></param>
        </member>
        <member name="P:BrightIdeasSoftware.IDropSink.ListView">
            <summary>
            Gets or sets the ObjectListView that is the drop sink
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractDropSink">
            <summary>
            This is a do-nothing implementation of IDropSink that is a useful
            base class for more sophisticated implementations.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDropSink.DrawFeedback(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw any feedback that is appropriate to the current drop state.
            </summary>
            <remarks>
            Any drawing is done over the top of the ListView. This operation should disturb
            the Graphic as little as possible. Specifically, do not erase the area into which
            you draw. 
            </remarks>
            <param name="g">A Graphic for drawing</param>
            <param name="bounds">The contents bounds of the ListView (not including any header)</param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDropSink.Drop(System.Windows.Forms.DragEventArgs)">
            <summary>
            The user has released the drop over this control
            </summary>
            <remarks>
            Implementators should set args.Effect to the appropriate DragDropEffects. This value is returned
            to the originator of the drag.
            </remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDropSink.Enter(System.Windows.Forms.DragEventArgs)">
            <summary>
            A drag has entered this control.
            </summary>
            <remarks>Implementators should set args.Effect to the appropriate DragDropEffects.</remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDropSink.Leave">
            <summary>
            The drag has left the bounds of this control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDropSink.Over(System.Windows.Forms.DragEventArgs)">
            <summary>
            The drag is moving over this control.
            </summary>
            <remarks>This is where any drop target should be calculated.
            Implementators should set args.Effect to the appropriate DragDropEffects.
            </remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDropSink.GiveFeedback(System.Windows.Forms.GiveFeedbackEventArgs)">
            <summary>
            Change the cursor to reflect the current drag operation.
            </summary>
            <remarks>You only need to override this if you want non-standard cursors.
            The standard cursors are supplied automatically.</remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDropSink.QueryContinue(System.Windows.Forms.QueryContinueDragEventArgs)">
            <summary>
            Should the drag be allowed to continue?
            </summary>
            <remarks>
            You only need to override this if you want the user to be able
            to end the drop in some non-standard way, e.g. dragging to a
            certain point even without releasing the mouse, or going outside
            the bounds of the application. 
            </remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractDropSink.Cleanup">
            <summary>
            This is called when the mouse leaves the drop region and after the
            drop has completed.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AbstractDropSink.ListView">
            <summary>
            Gets or sets the ObjectListView that is the drop sink
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.DropTargetLocation">
            <summary>
            The enum indicates which target has been found for a drop operation
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.None">
            <summary>
            No applicable target has been found
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.Background">
            <summary>
            The list itself is the target of the drop
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.Item">
            <summary>
            An item is the target
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.BetweenItems">
            <summary>
            Between two items (or above the top item or below the bottom item)
            can be the target. This is not actually ever a target, only a value indicate
            that it is valid to drop between items
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.AboveItem">
            <summary>
            Above an item is the target
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.BelowItem">
            <summary>
            Below an item is the target
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.SubItem">
            <summary>
            A subitem is the target of the drop
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.RightOfItem">
            <summary>
            On the right of an item is the target (not currently used)
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.DropTargetLocation.LeftOfItem">
            <summary>
            On the left of an item is the target (not currently used)
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.SimpleDropSink">
            <summary>
            This class represents a simple implementation of a drop sink.
            </summary>
            <remarks>
            Actually, it's far from simple and can do quite a lot in its own right.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.#ctor">
            <summary>
            Make a new drop sink
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.Cleanup">
            <summary>
            Cleanup the drop sink when the mouse has left the control or 
            the drag has finished.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.DrawFeedback(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw any feedback that is appropriate to the current drop state.
            </summary>
            <remarks>
            Any drawing is done over the top of the ListView. This operation should disturb
            the Graphic as little as possible. Specifically, do not erase the area into which
            you draw. 
            </remarks>
            <param name="g">A Graphic for drawing</param>
            <param name="bounds">The contents bounds of the ListView (not including any header)</param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.Drop(System.Windows.Forms.DragEventArgs)">
            <summary>
            The user has released the drop over this control
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.Enter(System.Windows.Forms.DragEventArgs)">
            <summary>
            A drag has entered this control.
            </summary>
            <remarks>Implementators should set args.Effect to the appropriate DragDropEffects.</remarks>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.GiveFeedback(System.Windows.Forms.GiveFeedbackEventArgs)">
            <summary>
            Change the cursor to reflect the current drag operation.
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.Over(System.Windows.Forms.DragEventArgs)">
            <summary>
            The drag is moving over this control.
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.TriggerDroppedEvent(System.Windows.Forms.DragEventArgs)">
            <summary>
            Trigger the Dropped events
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.OnCanDrop(BrightIdeasSoftware.OlvDropEventArgs)">
            <summary>
            Trigger CanDrop
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.OnDropped(BrightIdeasSoftware.OlvDropEventArgs)">
            <summary>
            Trigger Dropped
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.OnModelCanDrop(BrightIdeasSoftware.ModelDropEventArgs)">
            <summary>
            Trigger ModelCanDrop
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.OnModelDropped(BrightIdeasSoftware.ModelDropEventArgs)">
            <summary>
            Trigger ModelDropped
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.HandleTimerTick">
            <summary>
            Handle the timer tick event, which is sent when the listview should
            scroll
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.CalculateDropTarget(BrightIdeasSoftware.OlvDropEventArgs,System.Drawing.Point)">
            <summary>
            When the mouse is at the given point, what should the target of the drop be?
            </summary>
            <remarks>This method should update the DropTarget* members of the given arg block</remarks>
            <param name="args"></param>
            <param name="pt">The mouse point, in client co-ordinates</param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.CalculateDropAction(System.Windows.Forms.DragEventArgs,System.Drawing.Point)">
            <summary>
            What sort of action is possible when the mouse is at the given point?
            </summary>
            <remarks>
            </remarks>
            <param name="args"></param>
            <param name="pt"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.CalculateStandardDropActionFromKeys">
            <summary>
            Based solely on the state of the modifier keys, what drop operation should
            be used?
            </summary>
            <returns>The drop operation that matches the state of the keys</returns>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.CheckScrolling(System.Drawing.Point)">
            <summary>
            Should the listview be made to scroll when the mouse is at the given point?
            </summary>
            <param name="pt"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.UpdateAfterCanDropEvent(BrightIdeasSoftware.OlvDropEventArgs)">
            <summary>
            Update the state of our sink to reflect the information that 
            may have been written into the drop event args.
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.DrawFeedbackBackgroundTarget(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the feedback that shows that the background is the target
            </summary>
            <param name="g"></param>
            <param name="bounds"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.DrawFeedbackItemTarget(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the feedback that shows that an item (or a subitem) is the target
            </summary>
            <param name="g"></param>
            <param name="bounds"></param>
            <remarks>
            DropTargetItem and DropTargetSubItemIndex tells what is the target
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.DrawFeedbackAboveItemTarget(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the feedback that shows the drop will occur before target
            </summary>
            <param name="g"></param>
            <param name="bounds"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.DrawFeedbackBelowItemTarget(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the feedback that shows the drop will occur after target
            </summary>
            <param name="g"></param>
            <param name="bounds"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.GetRoundedRect(System.Drawing.Rectangle,System.Single)">
            <summary>
            Return a GraphicPath that is round corner rectangle.
            </summary>
            <param name="rect"></param>
            <param name="diameter"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.CalculateDropTargetRectangle(BrightIdeasSoftware.OLVListItem,System.Int32)">
            <summary>
            Calculate the target rectangle when the given item (and possible subitem)
            is the target of the drop.
            </summary>
            <param name="item"></param>
            <param name="subItem"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleDropSink.DrawBetweenLine(System.Drawing.Graphics,System.Int32,System.Int32,System.Int32,System.Int32)">
            <summary>
            Draw a "between items" line at the given co-ordinates
            </summary>
            <param name="g"></param>
            <param name="x1"></param>
            <param name="y1"></param>
            <param name="x2"></param>
            <param name="y2"></param>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.AcceptableLocations">
            <summary>
            Get or set the locations where a drop is allowed to occur (OR-ed together)
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.AcceptExternal">
            <summary>
            Gets or sets whether this sink allows model objects to be dragged from other lists
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.AutoScroll">
            <summary>
            Gets or sets whether the ObjectListView should scroll when the user drags
            something near to the top or bottom rows.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.Billboard">
            <summary>
            Gets the billboard overlay that will be used to display feedback
            messages during a drag operation. 
            </summary>
            <remarks>Set this to null to stop the feedback.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.CanDropBetween">
            <summary>
            Get or set whether a drop can occur between items of the list
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.CanDropOnBackground">
            <summary>
            Get or set whether a drop can occur on the listview itself
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.CanDropOnItem">
            <summary>
            Get or set whether a drop can occur on items in the list
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.CanDropOnSubItem">
            <summary>
            Get or set whether a drop can occur on a subitem in the list
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.DropTargetIndex">
            <summary>
            Get or set the index of the item that is the target of the drop
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.DropTargetItem">
            <summary>
            Get the item that is the target of the drop
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.DropTargetLocation">
            <summary>
            Get or set the location of the target of the drop
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.DropTargetSubItemIndex">
            <summary>
            Get or set the index of the subitem that is the target of the drop
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.FeedbackColor">
            <summary>
            Get or set the color that will be used to provide drop feedback
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.IsAltDown">
            <summary>
            Get whether the alt key was down during this drop event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.IsAnyModifierDown">
            <summary>
            Get whether any modifier key was down during this drop event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.IsControlDown">
            <summary>
            Get whether the control key was down during this drop event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.IsLeftMouseButtonDown">
            <summary>
            Get whether the left mouse button was down during this drop event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.IsMiddleMouseButtonDown">
            <summary>
            Get whether the right mouse button was down during this drop event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.IsRightMouseButtonDown">
            <summary>
            Get whether the right mouse button was down during this drop event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.IsShiftDown">
            <summary>
            Get whether the shift key was down during this drop event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.KeyState">
            <summary>
            Get or set the state of the keys during this drop event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleDropSink.UseDefaultCursors">
            <summary>
            Gets or sets whether the drop sink will automatically use cursors
            based on the drop effect. By default, this is true. If this is
            set to false, you must set the Cursor yourself.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.SimpleDropSink.CanDrop">
            <summary>
            Triggered when the sink needs to know if a drop can occur.
            </summary>
            <remarks>
            Handlers should set Effect to indicate what is possible.
            Handlers can change any of the DropTarget* setttings to change
            the target of the drop.
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.SimpleDropSink.Dropped">
            <summary>
            Triggered when the drop is made.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.SimpleDropSink.ModelCanDrop">
            <summary>
            Triggered when the sink needs to know if a drop can occur
            AND the source is an ObjectListView
            </summary>
            <remarks>
            Handlers should set Effect to indicate what is possible.
            Handlers can change any of the DropTarget* setttings to change
            the target of the drop.
            </remarks>
        </member>
        <member name="E:BrightIdeasSoftware.SimpleDropSink.ModelDropped">
            <summary>
            Triggered when the drop is made.
            AND the source is an ObjectListView
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.RearrangingDropSink">
            <summary>
            This drop sink allows items within the same list to be rearranged,
            as well as allowing items to be dropped from other lists.
            </summary>
            <remarks>
            <para>
            This class can only be used on plain ObjectListViews and FastObjectListViews.
            The other flavours have no way to implement the insert operation that is required.
            </para>
            <para>
            This class does not work with grouping.
            </para>
            <para>
            This class works when the OLV is sorted, but it is up to the programmer
            to decide what rearranging such lists "means". Example: if the control is sorting
            students by academic grade, and the user drags a "Fail" grade student up amonst the "A+"
            students, it is the responsibility of the programmer to makes the appropriate changes
            to the model and redraw/rebuild the control so that the users action makes sense.
            </para>
            <para>
            Users of this class should listen for the CanDrop event to decide
            if models from another OLV can be moved to OLV under this sink.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.RearrangingDropSink.#ctor">
            <summary>
            Create a RearrangingDropSink
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.RearrangingDropSink.#ctor(System.Boolean)">
            <summary>
            Create a RearrangingDropSink
            </summary>
            <param name="acceptDropsFromOtherLists"></param>
        </member>
        <member name="M:BrightIdeasSoftware.RearrangingDropSink.OnModelCanDrop(BrightIdeasSoftware.ModelDropEventArgs)">
            <summary>
            Trigger OnModelCanDrop
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.RearrangingDropSink.OnModelDropped(BrightIdeasSoftware.ModelDropEventArgs)">
            <summary>
            Trigger OnModelDropped
            </summary>
            <param name="args"></param>
        </member>
        <member name="M:BrightIdeasSoftware.RearrangingDropSink.RearrangeModels(BrightIdeasSoftware.ModelDropEventArgs)">
            <summary>
            Do the work of processing the dropped items
            </summary>
            <param name="args"></param>
        </member>
        <member name="T:BrightIdeasSoftware.OlvDropEventArgs">
            <summary>
            When a drop sink needs to know if something can be dropped, or
            to notify that a drop has occured, it uses an instance of this class.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OlvDropEventArgs.#ctor">
            <summary>
            Create a OlvDropEventArgs
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.DragEventArgs">
            <summary>
            Get the original drag-drop event args
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.DataObject">
            <summary>
            Get the data object that is being dragged
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.DropSink">
            <summary>
            Get the drop sink that originated this event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.DropTargetIndex">
            <summary>
            Get or set the index of the item that is the target of the drop
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.DropTargetLocation">
            <summary>
            Get or set the location of the target of the drop
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.DropTargetSubItemIndex">
            <summary>
            Get or set the index of the subitem that is the target of the drop
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.DropTargetItem">
            <summary>
            Get the item that is the target of the drop
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.Effect">
            <summary>
            Get or set the drag effect that should be used for this operation
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.Handled">
            <summary>
            Get or set if this event was handled. No further processing will be done for a handled event.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.InfoMessage">
            <summary>
            Get or set the feedback message for this operation
            </summary>
            <remarks>
            If this is not null, it will be displayed as a feedback message
            during the drag.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.ListView">
            <summary>
            Get the ObjectListView that is being dropped on
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.MouseLocation">
            <summary>
            Get the location of the mouse (in target ListView co-ords)
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OlvDropEventArgs.StandardDropActionFromKeys">
            <summary>
            Get the drop action indicated solely by the state of the modifier keys
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ModelDropEventArgs">
            <summary>
            These events are triggered when the drag source is an ObjectListView.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ModelDropEventArgs.#ctor">
            <summary>
            Create a ModelDropEventArgs
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ModelDropEventArgs.RefreshObjects">
            <summary>
            Refresh all the objects involved in the operation
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ModelDropEventArgs.SourceModels">
            <summary>
            Gets the model objects that are being dragged.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ModelDropEventArgs.SourceListView">
            <summary>
            Gets the ObjectListView that is the source of the dragged objects.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ModelDropEventArgs.TargetModel">
            <summary>
            Get the model object that is being dropped upon.
            </summary>
            <remarks>This is only value for TargetLocation == Item</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.CellEditEventHandler">
            <summary>
            The callbacks for CellEditing events
            </summary>
            <remarks> this 
            We could replace this with EventHandler&lt;CellEditEventArgs&gt; but that would break all
            cell editing event code from v1.x.
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.CellEditEventArgs">
            <summary>
            Let the world know that a cell edit operation is beginning or ending
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditEventArgs.#ctor(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.Control,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32)">
            <summary>
            Create an event args
            </summary>
            <param name="column"></param>
            <param name="control"></param>
            <param name="r"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditEventArgs.Cancel">
            <summary>
            Change this to true to cancel the cell editing operation.
            </summary>
            <remarks>
            <para>During the CellEditStarting event, setting this to true will prevent the cell from being edited.</para>
            <para>During the CellEditFinishing event, if this value is already true, this indicates that the user has
            cancelled the edit operation and that the handler should perform cleanup only. Setting this to true,
            will prevent the ObjectListView from trying to write the new value into the model object.</para>
            </remarks>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditEventArgs.Control">
            <summary>
            During the CellEditStarting event, this can be modified to be the control that you want
            to edit the value. You must fully configure the control before returning from the event,
            including its bounds and the value it is showing.
            During the CellEditFinishing event, you can use this to get the value that the user
            entered and commit that value to the model. Changing the control during the finishing
            event has no effect.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditEventArgs.Column">
            <summary>
            The column of the cell that is going to be or has been edited.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditEventArgs.RowObject">
            <summary>
            The model object of the row of the cell that is going to be or has been edited.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditEventArgs.ListViewItem">
            <summary>
            The listview item of the cell that is going to be or has been edited.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditEventArgs.NewValue">
            <summary>
            The data value of the cell as it stands in the control.
            </summary>
            <remarks>Only validate during Validating and Finishing events.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditEventArgs.SubItemIndex">
            <summary>
            The index of the cell that is going to be or has been edited.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditEventArgs.Value">
            <summary>
            The data value of the cell before the edit operation began.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditEventArgs.CellBounds">
            <summary>
            The bounds of the cell that is going to be or has been edited.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditEventArgs.AutoDispose">
            <summary>
            Gets or sets whether the control used for editing should be auto matically disposed
            when the cell edit operation finishes. Defaults to true
            </summary>
            <remarks>If the control is expensive to create, you might want to cache it and reuse for
            for various cells. If so, you don't want ObjectListView to dispose of the control automatically</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.CancellableEventArgs">
            <summary>
            Event blocks for events that can be cancelled
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CancellableEventArgs.Canceled">
            <summary>
            Has this event been cancelled by the event handler?
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.BeforeSortingEventArgs">
            <summary>
            BeforeSorting
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BeforeSortingEventArgs.#ctor(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Create BeforeSortingEventArgs
            </summary>
            <param name="column"></param>
            <param name="order"></param>
            <param name="column2"></param>
            <param name="order2"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BeforeSortingEventArgs.#ctor(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Create BeforeSortingEventArgs
            </summary>
            <param name="groupColumn"></param>
            <param name="groupOrder"></param>
            <param name="column"></param>
            <param name="order"></param>
            <param name="column2"></param>
            <param name="order2"></param>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSortingEventArgs.Handled">
            <summary>
            Did the event handler already do the sorting for us?
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSortingEventArgs.ColumnToGroupBy">
            <summary>
            What column will be used for grouping
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSortingEventArgs.GroupByOrder">
            <summary>
            How will groups be ordered
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSortingEventArgs.ColumnToSort">
            <summary>
            What column will be used for sorting
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSortingEventArgs.SortOrder">
            <summary>
            What order will be used for sorting. None means no sorting.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSortingEventArgs.SecondaryColumnToSort">
            <summary>
            What column will be used for secondary sorting?
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSortingEventArgs.SecondarySortOrder">
            <summary>
            What order will be used for secondary sorting?
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AfterSortingEventArgs">
            <summary>
            Sorting has just occurred.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AfterSortingEventArgs.#ctor(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Create a AfterSortingEventArgs
            </summary>
            <param name="groupColumn"></param>
            <param name="groupOrder"></param>
            <param name="column"></param>
            <param name="order"></param>
            <param name="column2"></param>
            <param name="order2"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AfterSortingEventArgs.#ctor(BrightIdeasSoftware.BeforeSortingEventArgs)">
            <summary>
            Create a AfterSortingEventArgs
            </summary>
            <param name="args"></param>
        </member>
        <member name="P:BrightIdeasSoftware.AfterSortingEventArgs.ColumnToGroupBy">
            <summary>
            What column was used for grouping?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AfterSortingEventArgs.GroupByOrder">
            <summary>
            What ordering was used for grouping?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AfterSortingEventArgs.ColumnToSort">
            <summary>
            What column was used for sorting?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AfterSortingEventArgs.SortOrder">
            <summary>
            What ordering was used for sorting?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AfterSortingEventArgs.SecondaryColumnToSort">
            <summary>
            What column was used for secondary sorting?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AfterSortingEventArgs.SecondarySortOrder">
            <summary>
            What order was used for secondary sorting?
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FilterEventArgs">
            <summary>
            This event is triggered when the contents of a list have changed
            and we want the world to have a chance to filter the list.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.FilterEventArgs.#ctor(System.Collections.IEnumerable)">
            <summary>
            Create a FilterEventArgs
            </summary>
            <param name="objects"></param>
        </member>
        <member name="F:BrightIdeasSoftware.FilterEventArgs.Objects">
            <summary>
            Gets or sets what objects are being filtered
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.FilterEventArgs.FilteredObjects">
            <summary>
            Gets or sets what objects survived the filtering
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ItemsChangedEventArgs">
            <summary>
            This event is triggered after the items in the list have been changed,
            either through SetObjects, AddObjects or RemoveObjects.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ItemsChangedEventArgs.#ctor">
            <summary>
            Create a ItemsChangedEventArgs
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ItemsChangedEventArgs.#ctor(System.Int32,System.Int32)">
            <summary>
            Constructor for this event when used by a virtual list
            </summary>
            <param name="oldObjectCount"></param>
            <param name="newObjectCount"></param>
        </member>
        <member name="P:BrightIdeasSoftware.ItemsChangedEventArgs.OldObjectCount">
            <summary>
            Gets how many items were in the list before it changed
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ItemsChangedEventArgs.NewObjectCount">
            <summary>
            Gets how many objects are in the list after the change.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ItemsAddingEventArgs">
            <summary>
            This event is triggered by AddObjects before any change has been made to the list.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ItemsAddingEventArgs.#ctor(System.Collections.ICollection)">
            <summary>
            Create an ItemsAddingEventArgs
            </summary>
            <param name="objectsToAdd"></param>
        </member>
        <member name="F:BrightIdeasSoftware.ItemsAddingEventArgs.ObjectsToAdd">
            <summary>
            Gets or sets the objects to be added to the list
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ItemsChangingEventArgs">
            <summary>
            This event is triggered by SetObjects before any change has been made to the list.
            </summary>
            <remarks>
            When used with a virtual list, OldObjects will always be null.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ItemsChangingEventArgs.#ctor(System.Collections.IEnumerable,System.Collections.IEnumerable)">
            <summary>
            Create ItemsChangingEventArgs
            </summary>
            <param name="oldObjects"></param>
            <param name="newObjects"></param>
        </member>
        <member name="F:BrightIdeasSoftware.ItemsChangingEventArgs.NewObjects">
            <summary>
            Gets or sets the objects that will be in the list after it changes.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ItemsChangingEventArgs.OldObjects">
            <summary>
            Gets the objects that were in the list before it change.
            For virtual lists, this will always be null.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ItemsRemovingEventArgs">
            <summary>
            This event is triggered by RemoveObjects before any change has been made to the list.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ItemsRemovingEventArgs.#ctor(System.Collections.ICollection)">
            <summary>
            Create an ItemsRemovingEventArgs
            </summary>
            <param name="objectsToRemove"></param>
        </member>
        <member name="F:BrightIdeasSoftware.ItemsRemovingEventArgs.ObjectsToRemove">
            <summary>
            Gets or sets the objects that will be removed
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AfterSearchingEventArgs">
            <summary>
            Triggered after the user types into a list
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AfterSearchingEventArgs.#ctor(System.String,System.Int32)">
            <summary>
            Create an AfterSearchingEventArgs
            </summary>
            <param name="stringToFind"></param>
            <param name="indexSelected"></param>
        </member>
        <member name="F:BrightIdeasSoftware.AfterSearchingEventArgs.Handled">
            <summary>
            Gets or sets whether an the event handler already handled this event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AfterSearchingEventArgs.StringToFind">
            <summary>
            Gets the string that was actually searched for
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.AfterSearchingEventArgs.IndexSelected">
            <summary>
            Gets the index of the row that was selected by the search.
            -1 means that no row was matched
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.BeforeSearchingEventArgs">
            <summary>
            Triggered when the user types into a list
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BeforeSearchingEventArgs.#ctor(System.String,System.Int32)">
            <summary>
            Create BeforeSearchingEventArgs
            </summary>
            <param name="stringToFind"></param>
            <param name="startSearchFrom"></param>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSearchingEventArgs.StringToFind">
            <summary>
            Gets or sets the string that will be found by the search routine
            </summary>
            <remarks>Modifying this value does not modify the memory of what the user has typed. 
            When the user next presses a character, the search string will revert to what 
            the user has actually typed.</remarks>
        </member>
        <member name="F:BrightIdeasSoftware.BeforeSearchingEventArgs.StartSearchFrom">
            <summary>
            Gets or sets the index of the first row that will be considered to matching.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CellEventArgs">
            <summary>
            The parameter block when telling the world about a cell based event
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEventArgs.Handled">
            <summary>
            Gets or set if this event completelely handled. If it was, no further processing
            will be done for it.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.ListView">
            <summary>
            Gets the ObjectListView that is the source of the event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.Model">
            <summary>
            Gets the model object under the cell
            </summary>
            <remarks>This is null for events triggered by the header.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.RowIndex">
            <summary>
            Gets the row index of the cell
            </summary>
            <remarks>This is -1 for events triggered by the header.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.ColumnIndex">
            <summary>
            Gets the column index of the cell
            </summary>
            <remarks>This is -1 when the view is not in details view.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.Column">
            <summary>
            Gets the column of the cell 
            </summary>
            <remarks>This is null when the view is not in details view.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.Location">
            <summary>
            Gets the location of the mouse at the time of the event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.ModifierKeys">
            <summary>
            Gets the state of the modifier keys at the time of the event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.Item">
            <summary>
            Gets the item of the cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.SubItem">
            <summary>
            Gets the subitem of the cell
            </summary>
            <remarks>This is null when the view is not in details view and 
            for event triggered by the header</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.CellEventArgs.HitTest">
            <summary>
            Gets the HitTest object that determined which cell was hit
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CellClickEventArgs">
            <summary>
            Tells the world that a cell was clicked
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellClickEventArgs.ClickCount">
            <summary>
            Gets or sets the number of clicks associated with this event
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CellRightClickEventArgs">
            <summary>
            Tells the world that a cell was right clicked
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellRightClickEventArgs.MenuStrip">
            <summary>
            Gets or sets the menu that should be displayed as a result of this event.
            </summary>
            <remarks>The menu will be positioned at Location, so changing that property changes
            where the menu will be displayed.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.CellOverEventArgs">
            <summary>
            Tell the world that the mouse is over a given cell
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FreezeEventArgs">
            <summary>
            Tells the world that the frozen-ness of the ObjectListView has changed.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.FreezeEventArgs.#ctor(System.Int32)">
            <summary>
            Make a FreezeEventArgs
            </summary>
            <param name="freeze"></param>
        </member>
        <member name="P:BrightIdeasSoftware.FreezeEventArgs.FreezeLevel">
            <summary>
            How frozen is the control? 0 means that the control is unfrozen, 
            more than 0 indicates froze.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ToolTipShowingEventArgs">
            <summary>
            The parameter block when telling the world that a tool tip is about to be shown.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.Text">
            <summary>
            Gets or sets the text should be shown on the tooltip for this event
            </summary>
            <remarks>Setting this to empty or null prevents any tooltip from showing</remarks>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.RightToLeft">
            <summary>
            In what direction should the text for this tooltip be drawn?
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.IsBalloon">
            <summary>
            Should the tooltip for this event been shown in bubble style?
            </summary>
            <remarks>This doesn't work reliable under Vista</remarks>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.BackColor">
            <summary>
            What color should be used for the background of the tooltip
            </summary>
            <remarks>Setting this does nothing under Vista</remarks>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.ForeColor">
            <summary>
            What color should be used for the foreground of the tooltip
            </summary>
            <remarks>Setting this does nothing under Vista</remarks>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.Title">
            <summary>
            What string should be used as the title for the tooltip for this event?
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.StandardIcon">
            <summary>
            Which standard icon should be used for the tooltip for this event
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.AutoPopDelay">
            <summary>
            How many milliseconds should the tooltip remain before it automatically
            disappears.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipShowingEventArgs.Font">
            <summary>
            What font should be used to draw the text of the tooltip?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipShowingEventArgs.ToolTipControl">
            <summary>
            Gets the tooltip control that is triggering the tooltip event
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HyperlinkEventArgs">
            <summary>
            Common information to all hyperlink events
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.ListView">
            <summary>
            Gets the ObjectListView that is the source of the event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.Model">
            <summary>
            Gets the model object under the cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.RowIndex">
            <summary>
            Gets the row index of the cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.ColumnIndex">
            <summary>
            Gets the column index of the cell
            </summary>
            <remarks>This is -1 when the view is not in details view.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.Column">
            <summary>
            Gets the column of the cell 
            </summary>
            <remarks>This is null when the view is not in details view.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.Item">
            <summary>
            Gets the item of the cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.SubItem">
            <summary>
            Gets the subitem of the cell
            </summary>
            <remarks>This is null when the view is not in details view</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.Url">
            <summary>
            Gets the ObjectListView that is the source of the event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkEventArgs.Handled">
            <summary>
            Gets or set if this event completelely handled. If it was, no further processing
            will be done for it.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IsHyperlinkEventArgs">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.IsHyperlinkEventArgs.Url">
            <summary>
            Gets or sets the url that should be invoked when this cell is clicked.
            </summary>
            <remarks>Setting this to None or String.Empty means that this cell is not a hyperlink</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.IsHyperlinkEventArgs.ListView">
            <summary>
            Gets the ObjectListView that is the source of the event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IsHyperlinkEventArgs.Model">
            <summary>
            Gets the model object under the cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IsHyperlinkEventArgs.Column">
            <summary>
            Gets the column of the cell 
            </summary>
            <remarks>This is null when the view is not in details view.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.IsHyperlinkEventArgs.Text">
            <summary>
            Gets the text of the cell 
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IsHyperlinkEventArgs.IsHyperlink">
            <summary>
            Gets or sets whether or not this cell is a hyperlink.
            Defaults to true for enabled rows and false for disabled rows. 
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FormatRowEventArgs">
            <summary>
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FormatRowEventArgs.ListView">
            <summary>
            Gets the ObjectListView that is the source of the event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FormatRowEventArgs.Item">
            <summary>
            Gets the item of the cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FormatRowEventArgs.Model">
            <summary>
            Gets the model object under the cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FormatRowEventArgs.RowIndex">
            <summary>
            Gets the row index of the cell
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FormatRowEventArgs.DisplayIndex">
            <summary>
            Gets the display index of the row
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FormatRowEventArgs.UseCellFormatEvents">
            <summary>
            Should events be triggered for each cell in this row?
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FormatCellEventArgs">
            <summary>
            Parameter block for FormatCellEvent
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FormatCellEventArgs.ColumnIndex">
            <summary>
            Gets the column index of the cell
            </summary>
            <remarks>This is -1 when the view is not in details view.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.FormatCellEventArgs.Column">
            <summary>
            Gets the column of the cell 
            </summary>
            <remarks>This is null when the view is not in details view.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.FormatCellEventArgs.SubItem">
            <summary>
            Gets the subitem of the cell
            </summary>
            <remarks>This is null when the view is not in details view</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.FormatCellEventArgs.CellValue">
            <summary>
            Gets the model value that is being displayed by the cell.
            </summary>
            <remarks>This is null when the view is not in details view</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.HyperlinkClickedEventArgs">
            <summary>
            The event args when a hyperlink is clicked
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkClickedEventArgs.Url">
            <summary>
            Gets the url that was associated with this cell.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HotItemChangedEventArgs">
            <summary>
            The event args when the hot item changed
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HotItemChangedEventArgs.ToString">
            <summary>
            Returns a string that represents the current object.
            </summary>
            <returns>
            A string that represents the current object.
            </returns>
            <filterpriority>2</filterpriority>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.Handled">
            <summary>
            Gets or set if this event completelely handled. If it was, no further processing
            will be done for it.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.HotCellHitLocation">
            <summary>
            Gets the part of the cell that the mouse is over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.HotCellHitLocationEx">
            <summary>
            Gets an extended indication of the part of item/subitem/group that the mouse is currently over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.HotColumnIndex">
            <summary>
            Gets the index of the column that the mouse is over
            </summary>
            <remarks>In non-details view, this will always be 0.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.HotRowIndex">
            <summary>
            Gets the index of the row that the mouse is over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.HotGroup">
            <summary>
            Gets the group that the mouse is over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.OldHotCellHitLocation">
            <summary>
            Gets the part of the cell that the mouse used to be over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.OldHotCellHitLocationEx">
            <summary>
            Gets an extended indication of the part of item/subitem/group that the mouse used to be over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.OldHotColumnIndex">
            <summary>
            Gets the index of the column that the mouse used to be over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.OldHotRowIndex">
            <summary>
            Gets the index of the row that the mouse used to be over
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemChangedEventArgs.OldHotGroup">
            <summary>
            Gets the group that the mouse used to be over
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.SubItemCheckingEventArgs">
            <summary>
            Let the world know that a checkbox on a subitem is changing
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.SubItemCheckingEventArgs.#ctor(BrightIdeasSoftware.OLVColumn,BrightIdeasSoftware.OLVListItem,System.Int32,System.Windows.Forms.CheckState,System.Windows.Forms.CheckState)">
            <summary>
            Create a new event block
            </summary>
            <param name="column"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="currentValue"></param>
            <param name="newValue"></param>
        </member>
        <member name="P:BrightIdeasSoftware.SubItemCheckingEventArgs.Column">
            <summary>
            The column of the cell that is having its checkbox changed.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SubItemCheckingEventArgs.RowObject">
            <summary>
            The model object of the row of the cell that is having its checkbox changed.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SubItemCheckingEventArgs.ListViewItem">
            <summary>
            The listview item of the cell that is having its checkbox changed.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SubItemCheckingEventArgs.CurrentValue">
            <summary>
            The current check state of the cell.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SubItemCheckingEventArgs.NewValue">
            <summary>
            The proposed new check state of the cell.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SubItemCheckingEventArgs.SubItemIndex">
            <summary>
            The index of the cell that is going to be or has been edited.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CreateGroupsEventArgs">
            <summary>
            This event argument block is used when groups are created for a list.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CreateGroupsEventArgs.#ctor(BrightIdeasSoftware.GroupingParameters)">
            <summary>
            Create a CreateGroupsEventArgs
            </summary>
            <param name="parms"></param>
        </member>
        <member name="P:BrightIdeasSoftware.CreateGroupsEventArgs.Parameters">
            <summary>
            Gets the settings that control the creation of groups
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CreateGroupsEventArgs.Groups">
            <summary>
            Gets or sets the groups that should be used
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CreateGroupsEventArgs.Canceled">
            <summary>
            Has this event been cancelled by the event handler?
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupTaskClickedEventArgs">
            <summary>
            This event argument block is used when the text of a group task is clicked
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.GroupTaskClickedEventArgs.#ctor(BrightIdeasSoftware.OLVGroup)">
            <summary>
            Create a GroupTaskClickedEventArgs
            </summary>
            <param name="group"></param>
        </member>
        <member name="P:BrightIdeasSoftware.GroupTaskClickedEventArgs.Group">
            <summary>
            Gets which group was clicked
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupExpandingCollapsingEventArgs">
            <summary>
            This event argument block is used when a group is about to expand or collapse
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.GroupExpandingCollapsingEventArgs.#ctor(BrightIdeasSoftware.OLVGroup)">
            <summary>
            Create a GroupExpandingCollapsingEventArgs
            </summary>
            <param name="group"> </param>
        </member>
        <member name="P:BrightIdeasSoftware.GroupExpandingCollapsingEventArgs.Group">
            <summary>
            Gets which group is expanding/collapsing
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupExpandingCollapsingEventArgs.IsExpanding">
            <summary>
            Gets whether this event is going to expand the group.
            If this is false, the group must be collapsing.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupStateChangedEventArgs">
            <summary>
            This event argument block is used when the state of group has changed (collapsed, selected)
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.GroupStateChangedEventArgs.#ctor(BrightIdeasSoftware.OLVGroup,BrightIdeasSoftware.GroupState,BrightIdeasSoftware.GroupState)">
            <summary>
            Create a GroupStateChangedEventArgs
            </summary>
            <param name="group"></param>
            <param name="oldState"> </param>
            <param name="newState"> </param>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.Collapsed">
            <summary>
            Gets whether the group was collapsed by this event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.Focused">
            <summary>
            Gets whether the group was focused by this event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.Selected">
            <summary>
            Gets whether the group was selected by this event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.Uncollapsed">
            <summary>
            Gets whether the group was uncollapsed by this event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.Unfocused">
            <summary>
            Gets whether the group was unfocused by this event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.Unselected">
            <summary>
            Gets whether the group was unselected by this event
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.Group">
            <summary>
            Gets which group had its state changed
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.OldState">
            <summary>
            Gets the previous state of the group
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.GroupStateChangedEventArgs.NewState">
            <summary>
            Gets the new state of the group
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeBranchExpandingEventArgs">
            <summary>
            This event argument block is used when a branch of a tree is about to be expanded
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeBranchExpandingEventArgs.#ctor(System.Object,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Create a new event args
            </summary>
            <param name="model"></param>
            <param name="item"></param>
        </member>
        <member name="P:BrightIdeasSoftware.TreeBranchExpandingEventArgs.Model">
            <summary>
            Gets the model that is about to expand. If null, all branches are going to be expanded.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeBranchExpandingEventArgs.Item">
            <summary>
            Gets the OLVListItem that is about to be expanded
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeBranchExpandedEventArgs">
            <summary>
            This event argument block is used when a branch of a tree has just been expanded
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeBranchExpandedEventArgs.#ctor(System.Object,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Create a new event args
            </summary>
            <param name="model"></param>
            <param name="item"></param>
        </member>
        <member name="P:BrightIdeasSoftware.TreeBranchExpandedEventArgs.Model">
            <summary>
            Gets the model that is was expanded. If null, all branches were expanded.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeBranchExpandedEventArgs.Item">
            <summary>
            Gets the OLVListItem that was expanded
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeBranchCollapsingEventArgs">
            <summary>
            This event argument block is used when a branch of a tree is about to be collapsed
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeBranchCollapsingEventArgs.#ctor(System.Object,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Create a new event args
            </summary>
            <param name="model"></param>
            <param name="item"></param>
        </member>
        <member name="P:BrightIdeasSoftware.TreeBranchCollapsingEventArgs.Model">
            <summary>
            Gets the model that is about to collapse. If this is null, all models are going to collapse.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeBranchCollapsingEventArgs.Item">
            <summary>
            Gets the OLVListItem that is about to be collapsed. Can be null
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TreeBranchCollapsedEventArgs">
            <summary>
            This event argument block is used when a branch of a tree has just been collapsed
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TreeBranchCollapsedEventArgs.#ctor(System.Object,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Create a new event args
            </summary>
            <param name="model"></param>
            <param name="item"></param>
        </member>
        <member name="P:BrightIdeasSoftware.TreeBranchCollapsedEventArgs.Model">
            <summary>
            Gets the model that is was collapsed. If null, all branches were collapsed
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TreeBranchCollapsedEventArgs.Item">
            <summary>
            Gets the OLVListItem that was collapsed
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FastDataListView">
            <summary>
            A FastDataListView virtualizes the display of data from a DataSource. It operates on
            DataSets and DataTables in the same way as a DataListView, but does so much more efficiently.
            </summary>
            <remarks>
            <para>
            A FastDataListView still has to load all its data from the DataSource. If you have SQL statement
            that returns 1 million rows, all 1 million rows will still need to read from the database.
            However, once the rows are loaded, the FastDataListView will only build rows as they are displayed.
            </para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.FastObjectListView">
            <summary>
            A FastObjectListView trades function for speed.
            </summary>
            <remarks>
            <para>On my mid-range laptop, this view builds a list of 10,000 objects in 0.1 seconds,
            as opposed to a normal ObjectListView which takes 10-15 seconds. Lists of up to 50,000 items should be
            able to be handled with sub-second response times even on low end machines.</para>
            <para>
            A FastObjectListView is implemented as a virtual list with many of the virtual modes limits (e.g. no sorting)
            fixed through coding. There are some functions that simply cannot be provided. Specifically, a FastObjectListView cannot:
            <list type="bullet">
            <item><description>use Tile view</description></item>
            <item><description>show groups on XP</description></item>
            </list>
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListView.#ctor">
            <summary>
            Make a FastObjectListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListView.Unsort">
            <summary>
            Remove any sorting and revert to the given order of the model objects
            </summary>
            <remarks>To be really honest, Unsort() doesn't work on FastObjectListViews since
            the original ordering of model objects is lost when Sort() is called. So this method
            effectively just turns off sorting.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.FastObjectListView.FilteredObjects">
            <summary>
            Gets the collection of objects that survive any filtering that may be in place.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FastObjectListView.Objects">
            <summary>
            Get/set the collection of objects that this list will show
            </summary>
            <remarks>
            <para>
            The contents of the control will be updated immediately after setting this property.
            </para>
            <para>This method preserves selection, if possible. Use SetObjects() if
            you do not want to preserve the selection. Preserving selection is the slowest part of this
            code and performance is O(n) where n is the number of selected rows.</para>
            <para>This method is not thread safe.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.FastDataListView.CreateDataSourceAdapter">
            <summary>
            Create the DataSourceAdapter that this control will use.
            </summary>
            <returns>A DataSourceAdapter configured for this list</returns>
            <remarks>Subclasses should overrride this to create their
            own specialized adapters</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.FastDataListView.DataSource">
            <summary>
            Get or set the VirtualListDataSource that will be displayed in this list view.
            </summary>
            <remarks>The VirtualListDataSource should implement either <see cref="T:System.Collections.IList"/>, <see cref="T:System.ComponentModel.IBindingList"/>,
            or <see cref="T:System.ComponentModel.IListSource"/>. Some common examples are the following types of objects:
            <list type="unordered">
            <item><description><see cref="T:System.Data.DataView"/></description></item>
            <item><description><see cref="T:System.Data.DataTable"/></description></item>
            <item><description><see cref="T:System.Data.DataSet"/></description></item>
            <item><description><see cref="T:System.Data.DataViewManager"/></description></item>
            <item><description><see cref="T:System.Windows.Forms.BindingSource"/></description></item>
            </list>
            <para>When binding to a list container (i.e. one that implements the
            <see cref="T:System.ComponentModel.IListSource"/> interface, such as <see cref="T:System.Data.DataSet"/>)
            you must also set the <see cref="P:BrightIdeasSoftware.FastDataListView.DataMember"/> property in order
            to identify which particular list you would like to display. You
            may also set the <see cref="P:BrightIdeasSoftware.FastDataListView.DataMember"/> property even when
            VirtualListDataSource refers to a list, since <see cref="P:BrightIdeasSoftware.FastDataListView.DataMember"/> can
            also be used to navigate relations between lists.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.FastDataListView.DataMember">
            <summary>
            Gets or sets the name of the list or table in the data source for which the DataListView is displaying data.
            </summary>
            <remarks>If the data source is not a DataSet or DataViewManager, this property has no effect</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.FastDataListView.Adapter">
            <summary>
            Gets or sets the DataSourceAdaptor that does the bulk of the work needed
            for data binding.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.Cluster">
            <summary>
            Concrete implementation of the ICluster interface.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ICluster">
            <summary>
            A cluster is a like collection of objects that can be usefully filtered
            as whole using the filtering UI provided by the ObjectListView.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ICluster.Count">
            <summary>
            Gets or sets how many items belong to this cluster
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ICluster.DisplayLabel">
            <summary>
            Gets or sets the label that will be shown to the user to represent
            this cluster
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ICluster.ClusterKey">
            <summary>
            Gets or sets the actual data object that all members of this cluster
            have commonly returned.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.Cluster.#ctor(System.Object)">
            <summary>
            Create a cluster
            </summary>
            <param name="key">The key for the cluster</param>
        </member>
        <member name="M:BrightIdeasSoftware.Cluster.ToString">
            <summary>
            Return a string representation of this cluster
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Cluster.CompareTo(System.Object)">
            <summary>
            Return an indication of the ordering between this object and the given one
            </summary>
            <param name="other"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.Cluster.Count">
            <summary>
            Gets or sets how many items belong to this cluster
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.Cluster.DisplayLabel">
            <summary>
            Gets or sets the label that will be shown to the user to represent
            this cluster
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.Cluster.ClusterKey">
            <summary>
            Gets or sets the actual data object that all members of this cluster
            have commonly returned.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ClustersFromGroupsStrategy">
            <summary>
            This class calculates clusters from the groups that the column uses.
            </summary>
            <remarks>
            <para>
            This is the default strategy for all non-date, filterable columns.
            </para>
            <para>
            This class does not strictly mimic the groups created by the given column.
            In particular, if the programmer changes the default grouping technique
            by listening for grouping events, this class will not mimic that behaviour.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ClustersFromGroupsStrategy.GetClusterKey(System.Object)">
            <summary>
            Get the cluster key by which the given model will be partitioned by this strategy
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ClustersFromGroupsStrategy.GetClusterDisplayLabel(BrightIdeasSoftware.ICluster)">
            <summary>
            Gets the display label that the given cluster should use
            </summary>
            <param name="cluster"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.FastObjectListDataSource">
            <summary>
            Provide a data source for a FastObjectListView
            </summary>
            <remarks>
            This class isn't intended to be used directly, but it is left as a public
            class just in case someone wants to subclass it.
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractVirtualListDataSource">
            <summary>
            A do-nothing implementation of the VirtualListDataSource interface.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.#ctor(BrightIdeasSoftware.VirtualObjectListView)">
            <summary>
            Creates an AbstractVirtualListDataSource
            </summary>
            <param name="listView"></param>
        </member>
        <member name="F:BrightIdeasSoftware.AbstractVirtualListDataSource.listView">
            <summary>
            The list view that this data source is giving information to.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.GetNthObject(System.Int32)">
            <summary>
            
            </summary>
            <param name="n"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.GetObjectCount">
            <summary>
            
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.GetObjectIndex(System.Object)">
            <summary>
            
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.PrepareCache(System.Int32,System.Int32)">
            <summary>
            
            </summary>
            <param name="from"></param>
            <param name="to"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.SearchText(System.String,System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn)">
            <summary>
            
            </summary>
            <param name="value"></param>
            <param name="first"></param>
            <param name="last"></param>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.Sort(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            
            </summary>
            <param name="column"></param>
            <param name="order"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.AddObjects(System.Collections.ICollection)">
            <summary>
            
            </summary>
            <param name="modelObjects"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.RemoveObjects(System.Collections.ICollection)">
            <summary>
            
            </summary>
            <param name="modelObjects"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.SetObjects(System.Collections.IEnumerable)">
            <summary>
            
            </summary>
            <param name="collection"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.UpdateObject(System.Int32,System.Object)">
            <summary>
            Update/replace the nth object with the given object
            </summary>
            <param name="index"></param>
            <param name="modelObject"></param>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.DefaultSearchText(System.String,System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn,BrightIdeasSoftware.IVirtualListDataSource)">
            <summary>
            This is a useful default implementation of SearchText method, intended to be called
            by implementors of IVirtualListDataSource.
            </summary>
            <param name="value"></param>
            <param name="first"></param>
            <param name="last"></param>
            <param name="column"></param>
            <param name="source"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualListDataSource.ApplyFilters(BrightIdeasSoftware.IModelFilter,BrightIdeasSoftware.IListFilter)">
            <summary>
            
            </summary>
            <param name="modelFilter"></param>
            <param name="listFilter"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.#ctor(BrightIdeasSoftware.FastObjectListView)">
            <summary>
            Create a FastObjectListDataSource
            </summary>
            <param name="listView"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.GetNthObject(System.Int32)">
            <summary>
            Get n'th object
            </summary>
            <param name="n"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.GetObjectCount">
            <summary>
            How many items are in the data source
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.GetObjectIndex(System.Object)">
            <summary>
            Get the index of the given model
            </summary>
            <param name="model"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.SearchText(System.String,System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn)">
            <summary>
            
            </summary>
            <param name="text"></param>
            <param name="first"></param>
            <param name="last"></param>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.Sort(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            
            </summary>
            <param name="column"></param>
            <param name="sortOrder"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.AddObjects(System.Collections.ICollection)">
            <summary>
            
            </summary>
            <param name="modelObjects"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.RemoveObjects(System.Collections.ICollection)">
            <summary>
            Remove the given collection of models from this source.
            </summary>
            <param name="modelObjects"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.SetObjects(System.Collections.IEnumerable)">
            <summary>
            
            </summary>
            <param name="collection"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.UpdateObject(System.Int32,System.Object)">
            <summary>
            Update/replace the nth object with the given object
            </summary>
            <param name="index"></param>
            <param name="modelObject"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.ApplyFilters(BrightIdeasSoftware.IModelFilter,BrightIdeasSoftware.IListFilter)">
            <summary>
            Apply the given filters to this data source. One or both may be null.
            </summary>
            <param name="iModelFilter"></param>
            <param name="iListFilter"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.RebuildIndexMap">
            <summary>
            Rebuild the map that remembers which model object is displayed at which line
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.FastObjectListDataSource.FilterObjects">
            <summary>
            Build our filtered list from our full list.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FastObjectListDataSource.ObjectList">
            <summary>
            Gets the full list of objects being used for this fast list. 
            This list is unfiltered.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FastObjectListDataSource.FilteredObjectList">
            <summary>
            Gets the list of objects from ObjectList which survive any installed filters.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FilterMenuBuilder">
            <summary>
            Instances of this class know how to build a Filter menu.
            It is responsible for clustering the values in the target column,
            build a menu that shows those clusters, and then constructing
            a filter that will enact the users choices.
            </summary>
            <remarks>
            Almost all of the methods in this class are declared as "virtual protected"
            so that subclasses can provide alternative behaviours.
            </remarks>
        </member>
        <member name="F:BrightIdeasSoftware.FilterMenuBuilder.APPLY_LABEL">
            <summary>
            Gets or sets the string that labels the Apply button.
            Exposed so it can be localized.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.FilterMenuBuilder.CLEAR_ALL_FILTERS_LABEL">
            <summary>
            Gets or sets the string that labels the Clear All menu item.
            Exposed so it can be localized.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.FilterMenuBuilder.FILTERING_LABEL">
            <summary>
            Gets or sets the string that labels the Filtering menu as a whole..
            Exposed so it can be localized.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.FilterMenuBuilder.SELECT_ALL_LABEL">
            <summary>
            Gets or sets the string that represents Select All values.
            If this is set to null or empty, no Select All option will be included.
            Exposed so it can be localized.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.FilterMenuBuilder.ClearFilteringImage">
            <summary>
            Gets or sets the image that will be placed next to the Clear Filtering menu item
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.FilterMenuBuilder.FilteringImage">
            <summary>
            Gets or sets the image that will be placed next to all "Apply" menu items on the filtering menu
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.MakeFilterMenu(System.Windows.Forms.ToolStripDropDown,BrightIdeasSoftware.ObjectListView,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Create a Filter menu on the given tool tip for the given column in the given ObjectListView.
            </summary>
            <remarks>This is the main entry point into this class.</remarks>
            <param name="strip"></param>
            <param name="listView"></param>
            <param name="column"></param>
            <returns>The strip that should be shown to the user</returns>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.Cluster(BrightIdeasSoftware.IClusteringStrategy,BrightIdeasSoftware.ObjectListView,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Create a collection of clusters that should be presented to the user
            </summary>
            <param name="strategy"></param>
            <param name="listView"></param>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.SortClusters(BrightIdeasSoftware.IClusteringStrategy,System.Collections.Generic.List{BrightIdeasSoftware.ICluster})">
            <summary>
            Order the given list of clusters in the manner in which they should be presented to the user.
            </summary>
            <param name="strategy"></param>
            <param name="clusters"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.CreateFilteringMenuItem(BrightIdeasSoftware.OLVColumn,System.Collections.Generic.List{BrightIdeasSoftware.ICluster})">
            <summary>
            Do the work of making a menu that shows the clusters to the users
            </summary>
            <param name="column"></param>
            <param name="clusters"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.HandleItemCheckedWrapped(System.Object,System.Windows.Forms.ItemCheckEventArgs)">
            <summary>
            Wrap a protected section around the real HandleItemChecked method, so that if
            that method tries to change a "checkedness" of an item, we don't get a recursive 
            stack error. Effectively, this ensure that HandleItemChecked is only called
            in response to a user action.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.HandleItemChecked(System.Object,System.Windows.Forms.ItemCheckEventArgs)">
            <summary>
            Handle a user-generated ItemCheck event
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.HandleSelectAllItem(System.Windows.Forms.ItemCheckEventArgs,BrightIdeasSoftware.ToolStripCheckedListBox,System.Int32)">
            <summary>
            Handle any checking/unchecking of the Select All option, and keep
            its checkedness in sync with everything else that is checked.
            </summary>
            <param name="e"></param>
            <param name="checkedList"></param>
            <param name="selectAllIndex"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.ClearAllFilters(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Clear all the filters that are applied to the given column
            </summary>
            <param name="column">The column from which filters are to be removed</param>
        </member>
        <member name="M:BrightIdeasSoftware.FilterMenuBuilder.EnactFilter(BrightIdeasSoftware.ToolStripCheckedListBox,BrightIdeasSoftware.OLVColumn)">
            <summary>
            Apply the selected values from the given list as a filter on the given column
            </summary>
            <param name="checkedList">A list in which the checked items should be used as filters</param>
            <param name="column">The column for which a filter should be generated</param>
        </member>
        <member name="P:BrightIdeasSoftware.FilterMenuBuilder.TreatNullAsDataValue">
            <summary>
            Gets or sets whether null should be considered as a valid data value.
            If this is true (the default), then a cluster will null as a key will be allow.
            If this is false, object that return a cluster key of null will ignored.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.FilterMenuBuilder.MaxObjectsToConsider">
            <summary>
            Gets or sets the maximum number of objects that the clustering strategy
            will consider. This should be large enough to collect all unique clusters,
            but small enough to finish in a reasonable time.
            </summary>
            <remarks>The default value is 10,000. This should be perfectly
            acceptable for almost all lists.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.IListFilter">
            <summary>
            Interface for whole list filtering
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IListFilter.Filter(System.Collections.IEnumerable)">
            <summary>
            Return a subset of the given list of model objects as the new
            contents of the ObjectListView
            </summary>
            <param name="modelObjects">The collection of model objects that the list will possibly display</param>
            <returns>The filtered collection that holds the model objects that will be displayed.</returns>
        </member>
        <member name="T:BrightIdeasSoftware.ModelFilter">
            <summary>
            This filter calls a given Predicate to decide if a model object should be included
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ModelFilter.#ctor(System.Predicate{System.Object})">
            <summary>
            Create a filter based on the given predicate
            </summary>
            <param name="predicate">The function that will filter objects</param>
        </member>
        <member name="M:BrightIdeasSoftware.ModelFilter.Filter(System.Object)">
            <summary>
            Should the given model object be included?
            </summary>
            <param name="modelObject"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.ModelFilter.Predicate">
            <summary>
            Gets or sets the predicate used to filter model objects
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CompositeFilter">
            <summary>
            A CompositeFilter joins several other filters together.
            If there are no filters, all model objects are included
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CompositeFilter.#ctor">
            <summary>
            Create an empty filter
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CompositeFilter.#ctor(System.Collections.Generic.IEnumerable{BrightIdeasSoftware.IModelFilter})">
            <summary>
            Create a composite filter from the given list of filters
            </summary>
            <param name="filters">A list of filters</param>
        </member>
        <member name="M:BrightIdeasSoftware.CompositeFilter.Filter(System.Object)">
            <summary>
            Decide whether or not the given model should be included by the filter
            </summary>
            <param name="modelObject"></param>
            <returns>True if the object is included by the filter</returns>
        </member>
        <member name="M:BrightIdeasSoftware.CompositeFilter.FilterObject(System.Object)">
            <summary>
            Decide whether or not the given model should be included by the filter
            </summary>
            <remarks>Filters is guaranteed to be non-empty when this method is called</remarks>
            <param name="modelObject">The model object under consideration</param>
            <returns>True if the object is included by the filter</returns>
        </member>
        <member name="P:BrightIdeasSoftware.CompositeFilter.Filters">
            <summary>
            Gets or sets the filters used by this composite
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CompositeAllFilter">
            <summary>
            A CompositeAllFilter joins several other filters together.
            A model object must satisfy all filters to be included.
            If there are no filters, all model objects are included
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CompositeAllFilter.#ctor(System.Collections.Generic.List{BrightIdeasSoftware.IModelFilter})">
            <summary>
            Create a filter
            </summary>
            <param name="filters"></param>
        </member>
        <member name="M:BrightIdeasSoftware.CompositeAllFilter.FilterObject(System.Object)">
            <summary>
            Decide whether or not the given model should be included by the filter
            </summary>
            <remarks>Filters is guaranteed to be non-empty when this method is called</remarks>
            <param name="modelObject">The model object under consideration</param>
            <returns>True if the object is included by the filter</returns>
        </member>
        <member name="T:BrightIdeasSoftware.CompositeAnyFilter">
            <summary>
            A CompositeAllFilter joins several other filters together.
            A model object must only satisfy one of the filters to be included.
            If there are no filters, all model objects are included
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CompositeAnyFilter.#ctor(System.Collections.Generic.List{BrightIdeasSoftware.IModelFilter})">
            <summary>
            Create a filter from the given filters
            </summary>
            <param name="filters"></param>
        </member>
        <member name="M:BrightIdeasSoftware.CompositeAnyFilter.FilterObject(System.Object)">
            <summary>
            Decide whether or not the given model should be included by the filter
            </summary>
            <remarks>Filters is guaranteed to be non-empty when this method is called</remarks>
            <param name="modelObject">The model object under consideration</param>
            <returns>True if the object is included by the filter</returns>
        </member>
        <member name="T:BrightIdeasSoftware.OneOfFilter">
            <summary>
            Instances of this class extract a value from the model object
            and compare that value to a list of fixed values. The model
            object is included if the extracted value is in the list
            </summary>
            <remarks>If there is no delegate installed or there are
            no values to match, no model objects will be matched</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.OneOfFilter.#ctor(BrightIdeasSoftware.AspectGetterDelegate)">
            <summary>
            Create a filter that will use the given delegate to extract values
            </summary>
            <param name="valueGetter"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OneOfFilter.#ctor(BrightIdeasSoftware.AspectGetterDelegate,System.Collections.ICollection)">
            <summary>
            Create a filter that will extract values using the given delegate
            and compare them to the values in the given list.
            </summary>
            <param name="valueGetter"></param>
            <param name="possibleValues"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OneOfFilter.Filter(System.Object)">
            <summary>
            Should the given model object be included?
            </summary>
            <param name="modelObject"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.OneOfFilter.DoesValueMatch(System.Object)">
            <summary>
            Decides if the given property is a match for the values in the PossibleValues collection
            </summary>
            <param name="result"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.OneOfFilter.ValueGetter">
            <summary>
            Gets or sets the delegate that will be used to extract values
            from model objects
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OneOfFilter.PossibleValues">
            <summary>
            Gets or sets the list of values that the value extracted from
            the model object must match in order to be included.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FlagBitSetFilter">
            <summary>
            Instances of this class match a property of a model objects against
            a list of bit flags. The property should be an xor-ed collection
            of bits flags.
            </summary>
            <remarks>Both the property compared and the list of possible values 
            must be convertible to ulongs.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.FlagBitSetFilter.#ctor(BrightIdeasSoftware.AspectGetterDelegate,System.Collections.ICollection)">
            <summary>
            Create an instance
            </summary>
            <param name="valueGetter"></param>
            <param name="possibleValues"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FlagBitSetFilter.DoesValueMatch(System.Object)">
            <summary>
            Decides if the given property is a match for the values in the PossibleValues collection
            </summary>
            <param name="result"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.FlagBitSetFilter.PossibleValues">
            <summary>
            Gets or sets the collection of values that will be matched.
            These must be ulongs (or convertible to ulongs).
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractListFilter">
            <summary>
            Base class for whole list filters
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractListFilter.Filter(System.Collections.IEnumerable)">
            <summary>
            Return a subset of the given list of model objects as the new
            contents of the ObjectListView
            </summary>
            <param name="modelObjects">The collection of model objects that the list will possibly display</param>
            <returns>The filtered collection that holds the model objects that will be displayed.</returns>
        </member>
        <member name="T:BrightIdeasSoftware.ListFilter">
            <summary>
            Instance of this class implement delegate based whole list filtering
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ListFilter.#ctor(BrightIdeasSoftware.ListFilter.ListFilterDelegate)">
            <summary>
            Create a ListFilter
            </summary>
            <param name="function"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ListFilter.Filter(System.Collections.IEnumerable)">
            <summary>
            Do the actual work of filtering
            </summary>
            <param name="modelObjects"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.ListFilter.Function">
            <summary>
            Gets or sets the delegate that will filter the list
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ListFilter.ListFilterDelegate">
            <summary>
            A delegate that filters on a whole list
            </summary>
            <param name="rowObjects"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.TailFilter">
            <summary>
            Filter the list so only the last N entries are displayed
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TailFilter.#ctor">
            <summary>
            Create a no-op tail filter
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TailFilter.#ctor(System.Int32)">
            <summary>
            Create a filter that includes on the last N model objects
            </summary>
            <param name="numberOfObjects"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TailFilter.Filter(System.Collections.IEnumerable)">
            <summary>
            Return the last N subset of the model objects
            </summary>
            <param name="modelObjects"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.TailFilter.Count">
            <summary>
            Gets or sets the number of model objects that will be 
            returned from the tail of the list
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ToolStripCheckedListBox">
            <summary>
            Instances of this class put a CheckedListBox into a tool strip menu item.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.#ctor">
            <summary>
            Create a ToolStripCheckedListBox
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.AddItem(System.Object,System.Boolean)">
            <summary>
            Add a possibly checked item to the control
            </summary>
            <param name="item"></param>
            <param name="isChecked"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.AddItem(System.Object,System.Windows.Forms.CheckState)">
            <summary>
            Add an item with the given state to the control
            </summary>
            <param name="item"></param>
            <param name="state"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.GetItemCheckState(System.Int32)">
            <summary>
            Gets the checkedness of the i'th item
            </summary>
            <param name="i"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.SetItemState(System.Int32,System.Windows.Forms.CheckState)">
            <summary>
            Set the checkedness of the i'th item
            </summary>
            <param name="i"></param>
            <param name="checkState"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.CheckAll">
            <summary>
            Check all the items in the control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.UncheckAll">
            <summary>
            Unchecked all the items in the control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.OnSubscribeControlEvents(System.Windows.Forms.Control)">
            <summary>
            Listen for events on the underlying control
            </summary>
            <param name="c"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.OnUnsubscribeControlEvents(System.Windows.Forms.Control)">
            <summary>
            Stop listening for events on the underlying control
            </summary>
            <param name="c"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolStripCheckedListBox.OnItemCheck(System.Object,System.Windows.Forms.ItemCheckEventArgs)">
            <summary>
            Trigger the ItemCheck event
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="P:BrightIdeasSoftware.ToolStripCheckedListBox.CheckedListBoxControl">
            <summary>
            Gets the control embedded in the menu
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolStripCheckedListBox.Items">
            <summary>
            Gets the items shown in the checkedlistbox
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolStripCheckedListBox.CheckedOnClick">
            <summary>
            Gets or sets whether an item should be checked when it is clicked
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolStripCheckedListBox.CheckedItems">
            <summary>
            Gets a collection of the checked items
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ToolStripCheckedListBox.ItemCheck">
            <summary>
            Tell the world that an item was checked
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ColumnSelectionForm">
            <summary>
            This form is an example of how an application could allows the user to select which columns 
            an ObjectListView will display, as well as select which order the columns are displayed in.
            </summary>
            <remarks>
            <para>In Tile view, ColumnHeader.DisplayIndex does nothing. To reorder the columns you have
            to change the order of objects in the Columns property.</para>
            <para>Remember that the first column is special!
            It has to remain the first column.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnSelectionForm.#ctor">
            <summary>
            Make a new ColumnSelectionForm
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnSelectionForm.OpenOn(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Open this form so it will edit the columns that are available in the listview's current view
            </summary>
            <param name="olv">The ObjectListView whose columns are to be altered</param>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnSelectionForm.OpenOn(BrightIdeasSoftware.ObjectListView,System.Windows.Forms.View)">
            <summary>
            Open this form so it will edit the columns that are available in the given listview
            when the listview is showing the given type of view.
            </summary>
            <param name="olv">The ObjectListView whose columns are to be altered</param>
            <param name="view">The view that is to be altered. Must be View.Details or View.Tile</param>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnSelectionForm.InitializeForm(BrightIdeasSoftware.ObjectListView,System.Windows.Forms.View)">
            <summary>
            Initialize the form to show the columns of the given view
            </summary>
            <param name="olv"></param>
            <param name="view"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnSelectionForm.Apply(BrightIdeasSoftware.ObjectListView,System.Windows.Forms.View)">
            <summary>
            The user has pressed OK. Do what's requied.
            </summary>
            <param name="olv"></param>
            <param name="view"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnSelectionForm.EnableControls">
            <summary>
            Enable the controls on the dialog to match the current state
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ColumnSelectionForm.components">
            <summary>
            Required designer variable.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnSelectionForm.Dispose(System.Boolean)">
            <summary>
            Clean up any resources being used.
            </summary>
            <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnSelectionForm.InitializeComponent">
            <summary>
            Required method for Designer support - do not modify
            the contents of this method with the code editor.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ColumnSelectionForm.SortByDisplayOrder">
            <summary>
            A Comparer that will sort a list of columns so that visible ones come before hidden ones,
            and that are ordered by their display order.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IGenerator">
            <summary>
            An object that implements the IGenerator interface provides the ability 
            to dynamically create columns
            for an ObjectListView based on the characteristics of a given collection
            of model objects.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IGenerator.GenerateAndReplaceColumns(BrightIdeasSoftware.ObjectListView,System.Type,System.Boolean)">
            <summary>
            Generate columns into the given ObjectListView that come from the given 
            model object type. 
            </summary>
            <param name="olv">The ObjectListView to modify</param>
            <param name="type">The model type whose attributes will be considered.</param>
            <param name="allProperties">Will columns be generated for properties that are not marked with [OLVColumn].</param>
        </member>
        <member name="M:BrightIdeasSoftware.IGenerator.GenerateColumns(System.Type,System.Boolean)">
            <summary>
            Generate a list of OLVColumns based on the attributes of the given type
            If allProperties to true, all public properties will have a matching column generated.
            If allProperties is false, only properties that have a OLVColumn attribute will have a column generated.
            </summary>
            <param name="type"></param>
            <param name="allProperties">Will columns be generated for properties that are not marked with [OLVColumn].</param>
            <returns>A collection of OLVColumns matching the attributes of Type that have OLVColumnAttributes.</returns>
        </member>
        <member name="T:BrightIdeasSoftware.Generator">
            <summary>
            The Generator class provides methods to dynamically create columns
            for an ObjectListView based on the characteristics of a given collection
            of model objects.
            </summary>
            <remarks>
            <para>For a given type, a Generator can create columns to match the public properties
            of that type. The generator can consider all public properties or only those public properties marked with
            [OLVColumn] attribute.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.GenerateColumns(BrightIdeasSoftware.ObjectListView,System.Collections.IEnumerable)">
            <summary>
            Replace all columns of the given ObjectListView with columns generated
            from the first member of the given enumerable. If the enumerable is 
            empty or null, the ObjectListView will be cleared.
            </summary>
            <param name="olv">The ObjectListView to modify</param>
            <param name="enumerable">The collection whose first element will be used to generate columns.</param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.GenerateColumns(BrightIdeasSoftware.ObjectListView,System.Collections.IEnumerable,System.Boolean)">
            <summary>
            Replace all columns of the given ObjectListView with columns generated
            from the first member of the given enumerable. If the enumerable is 
            empty or null, the ObjectListView will be cleared.
            </summary>
            <param name="olv">The ObjectListView to modify</param>
            <param name="enumerable">The collection whose first element will be used to generate columns.</param>
            <param name="allProperties">Will columns be generated for properties that are not marked with [OLVColumn].</param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.GenerateColumns(BrightIdeasSoftware.ObjectListView,System.Type)">
            <summary>
            Generate columns into the given ObjectListView that come from the public properties of the given 
            model object type. 
            </summary>
            <param name="olv">The ObjectListView to modify</param>
            <param name="type">The model type whose attributes will be considered.</param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.GenerateColumns(BrightIdeasSoftware.ObjectListView,System.Type,System.Boolean)">
            <summary>
            Generate columns into the given ObjectListView that come from the public properties of the given 
            model object type. 
            </summary>
            <param name="olv">The ObjectListView to modify</param>
            <param name="type">The model type whose attributes will be considered.</param>
            <param name="allProperties">Will columns be generated for properties that are not marked with [OLVColumn].</param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.GenerateColumns(System.Type)">
            <summary>
            Generate a list of OLVColumns based on the public properties of the given type
            that have a OLVColumn attribute.
            </summary>
            <param name="type"></param>
            <returns>A collection of OLVColumns matching the attributes of Type that have OLVColumnAttributes.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.GenerateAndReplaceColumns(BrightIdeasSoftware.ObjectListView,System.Type,System.Boolean)">
            <summary>
            Generate columns into the given ObjectListView that come from the given 
            model object type. 
            </summary>
            <param name="olv">The ObjectListView to modify</param>
            <param name="type">The model type whose attributes will be considered.</param>
            <param name="allProperties">Will columns be generated for properties that are not marked with [OLVColumn].</param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.GenerateColumns(System.Type,System.Boolean)">
            <summary>
            Generate a list of OLVColumns based on the attributes of the given type
            If allProperties to true, all public properties will have a matching column generated.
            If allProperties is false, only properties that have a OLVColumn attribute will have a column generated.
            </summary>
            <param name="type"></param>
            <param name="allProperties">Will columns be generated for properties that are not marked with [OLVColumn].</param>
            <returns>A collection of OLVColumns matching the attributes of Type that have OLVColumnAttributes.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.ReplaceColumns(BrightIdeasSoftware.ObjectListView,System.Collections.Generic.IList{BrightIdeasSoftware.OLVColumn})">
            <summary>
            Replace all the columns in the given listview with the given list of columns.
            </summary>
            <param name="olv"></param>
            <param name="columns"></param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.PostCreateColumns(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Post process columns after creating them and adding them to the AllColumns collection.
            </summary>
            <param name="olv"></param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.MakeColumnFromAttribute(System.Reflection.PropertyInfo,BrightIdeasSoftware.OLVColumnAttribute)">
            <summary>
            Create a column from the given PropertyInfo and OLVColumn attribute
            </summary>
            <param name="pinfo"></param>
            <param name="attr"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.MakeColumnFromPropertyInfo(System.Reflection.PropertyInfo)">
            <summary>
            Make a column from the given PropertyInfo
            </summary>
            <param name="pinfo"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.MakeColumnFromPropertyDescriptor(System.ComponentModel.PropertyDescriptor)">
            <summary>
            Make a column from the given PropertyDescriptor
            </summary>
            <param name="pd"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.MakeColumn(System.String,System.String,System.Boolean,System.Type,BrightIdeasSoftware.OLVColumnAttribute)">
            <summary>
            Create a column with all the given information
            </summary>
            <param name="aspectName"></param>
            <param name="title"></param>
            <param name="editable"></param>
            <param name="propertyType"></param>
            <param name="attr"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.MakeColumn(System.String,System.String,BrightIdeasSoftware.OLVColumnAttribute)">
            <summary>
            Create a column.
            </summary>
            <param name="aspectName"></param>
            <param name="title"></param>
            <param name="attr"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.DisplayNameToColumnTitle(System.String)">
            <summary>
            Convert a property name to a displayable title.
            </summary>
            <param name="displayName"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.ConfigurePossibleBooleanColumn(BrightIdeasSoftware.OLVColumn,System.Type)">
            <summary>
            Configure the given column to show a checkbox if appropriate
            </summary>
            <param name="column"></param>
            <param name="propertyType"></param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.TryGenerateChildrenDelegates(BrightIdeasSoftware.TreeListView,System.Type)">
            <summary>
            If this given type has an property marked with [OLVChildren], make delegates that will
            traverse that property as the children of an instance of the model
            </summary>
            <param name="tlv"></param>
            <param name="type"></param>
        </member>
        <member name="M:BrightIdeasSoftware.Generator.GenerateChildrenDelegates(BrightIdeasSoftware.TreeListView,System.Reflection.PropertyInfo)">
            <summary>
            Generate CanExpand and ChildrenGetter delegates from the given property.
            </summary>
            <param name="tlv"></param>
            <param name="pinfo"></param>
        </member>
        <member name="P:BrightIdeasSoftware.Generator.Instance">
            <summary>
            Gets or sets the actual generator used by the static convinence methods.
            </summary>
            <remarks>If you subclass the standard generator or implement IGenerator yourself, 
            you should install an instance of your subclass/implementation here.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.GlassPanelForm">
            <summary>
            A GlassPanelForm sits transparently over an ObjectListView to show overlays.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.Bind(BrightIdeasSoftware.ObjectListView,BrightIdeasSoftware.IOverlay)">
            <summary>
            Attach this form to the given ObjectListView
            </summary>        
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.HideGlass">
            <summary>
            Made the overlay panel invisible
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.ShowGlass">
            <summary>
            Show the overlay panel in its correctly location
            </summary>
            <remarks>
            If the panel is always shown, this method does nothing.
            If the panel is being resized, this method also does nothing.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.Unbind">
            <summary>
            Detach this glass panel from its previous ObjectListView
            </summary>        
            <remarks>
            You should unbind the overlay panel before making any changes to the 
            widget hierarchy.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.Owner_ResizeBegin(System.Object,System.EventArgs)">
            <summary>
            Handle when the form that owns the ObjectListView begins to be resized
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.Owner_ResizeEnd(System.Object,System.EventArgs)">
            <summary>
            Handle when the form that owns the ObjectListView finished to be resized
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.Owner_LocationChanged(System.Object,System.EventArgs)">
            <summary>
            The owning form has moved. Move the overlay panel too.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.Owner_SizeChanged(System.Object,System.EventArgs)">
            <summary>
            The owning form is resizing. Hide our overlay panel until the resizing stops
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.objectListView_LocationChanged(System.Object,System.EventArgs)">
            <summary>
            Handle when the bound OLV changes its location. The overlay panel must 
            be moved too, IFF it is currently visible.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.objectListView_SizeChanged(System.Object,System.EventArgs)">
            <summary>
            Handle when the bound OLV changes size. The overlay panel must 
            resize too, IFF it is currently visible.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.tabControl_Selected(System.Object,System.Windows.Forms.TabControlEventArgs)">
            <summary>
            Handle when the bound OLV is part of a TabControl and that
            TabControl changes tabs. The overlay panel is hidden. The
            first time the bound OLV is redrawn, the overlay panel will
            be shown again.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.objectListView_ParentChanged(System.Object,System.EventArgs)">
            <summary>
            Somewhere the parent of the bound OLV has changed. Update
            our events.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.GlassPanelForm.objectListView_VisibleChanged(System.Object,System.EventArgs)">
            <summary>
            Handle when the bound OLV changes its visibility.
            The overlay panel should match the OLV's visibility.
            </summary>
            <param name="sender"></param>
            <param name="e"></param>
        </member>
        <member name="P:BrightIdeasSoftware.GlassPanelForm.CreateParams">
            <summary>
            Get the low-level windows flag that will be given to CreateWindow.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupState">
            <summary>
            These values indicate what is the state of the group. These values
            are taken directly from the SDK and many are not used by ObjectListView.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_NORMAL">
            <summary>
            Normal
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_COLLAPSED">
            <summary>
            Collapsed
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_HIDDEN">
            <summary>
            Hidden
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_NOHEADER">
            <summary>
            NoHeader
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_COLLAPSIBLE">
            <summary>
            Can be collapsed
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_FOCUSED">
            <summary>
            Has focus
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_SELECTED">
            <summary>
            Is Selected
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_SUBSETED">
            <summary>
            Is subsetted
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_SUBSETLINKFOCUSED">
            <summary>
            Subset link has focus
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupState.LVGS_ALL">
            <summary>
            All styles
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupMask">
            <summary>
            This mask indicates which members of a LVGROUP have valid data. These values
            are taken directly from the SDK and many are not used by ObjectListView.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_NONE">
            <summary>
            No mask
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_HEADER">
            <summary>
            Group has header
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_FOOTER">
            <summary>
            Group has footer
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_STATE">
            <summary>
            Group has state
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_ALIGN">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_GROUPID">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_SUBTITLE">
            <summary>
            pszSubtitle is valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_TASK">
            <summary>
            pszTask is valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_DESCRIPTIONTOP">
            <summary>
            pszDescriptionTop is valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_DESCRIPTIONBOTTOM">
            <summary>
            pszDescriptionBottom is valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_TITLEIMAGE">
            <summary>
            iTitleImage is valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_EXTENDEDIMAGE">
            <summary>
            iExtendedImage is valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_ITEMS">
            <summary>
            iFirstItem and cItems are valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_SUBSET">
            <summary>
            pszSubsetTitle is valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMask.LVGF_SUBSETITEMS">
            <summary>
            readonly, cItems holds count of items in visible subset, iFirstItem is valid
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.GroupMetricsMask">
            <summary>
            This mask indicates which members of a GROUPMETRICS structure are valid
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMetricsMask.LVGMF_NONE">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMetricsMask.LVGMF_BORDERSIZE">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMetricsMask.LVGMF_BORDERCOLOR">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.GroupMetricsMask.LVGMF_TEXTCOLOR">
            <summary>
            
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVGroup">
            <summary>
            Instances of this class enhance the capabilities of a normal ListViewGroup,
            enabling the functionality that was released in v6 of the common controls.
            </summary>
            <remarks>
            <para>
            In this implementation (2009-09), these objects are essentially passive.
            Setting properties does not automatically change the associated group in
            the listview. Collapsed and Collapsible are two exceptions to this and 
            give immediate results.
            </para>
            <para>
            This really should be a subclass of ListViewGroup, but that class is 
            sealed (why is that?). So this class provides the same interface as a
            ListViewGroup, plus many other new properties.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.#ctor">
            <summary>
            Create an OLVGroup
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.#ctor(System.String)">
            <summary>
            Create a group with the given title
            </summary>
            <param name="header">Title of the group</param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.GetImageIndex(System.Object)">
            <summary>
            Calculate the index into the group image list of the given image selector
            </summary>
            <param name="imageSelector"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.ToString">
            <summary>
            Convert this object to a string representation
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.InsertGroupNewStyle(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Insert a native group into the underlying Windows control,
            *without* using a ListViewGroup
            </summary>
            <param name="olv"></param>
            <remarks>This is used when creating virtual groups</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.InsertGroupOldStyle(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Insert a native group into the underlying control via a ListViewGroup
            </summary>
            <param name="olv"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.SetItemsOldStyle">
            <summary>
            Change the members of the group to match the current contents of Items,
            using a ListViewGroup
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.AsNativeGroup(System.Boolean)">
            <summary>
            Create a native LVGROUP structure that matches this group
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.GetState">
            <summary>
            Get the current state of this group from the underlying control
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroup.SetState(BrightIdeasSoftware.GroupState,BrightIdeasSoftware.GroupState)">
            <summary>
            Get the current state of this group from the underlying control
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.BottomDescription">
            <summary>
            Gets or sets the bottom description of the group
            </summary>
            <remarks>
            Descriptions only appear when group is centered and there is a title image
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Collapsed">
            <summary>
            Gets or sets whether or not this group is collapsed
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Collapsible">
            <summary>
            Gets or sets whether or not this group can be collapsed
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Contents">
            <summary>
            Gets or sets some representation of the contents of this group
            </summary>
            <remarks>This is user defined (like Tag)</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Created">
            <summary>
            Gets whether this group has been created.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.ExtendedImage">
            <summary>
            Gets or sets the int or string that will select the extended image to be shown against the title
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Footer">
            <summary>
            Gets or sets the footer of the group
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.GroupId">
            <summary>
            Gets the internal id of our associated ListViewGroup.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Header">
            <summary>
            Gets or sets the header of the group
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.HeaderAlignment">
            <summary>
            Gets or sets the horizontal alignment of the group header
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Id">
            <summary>
            Gets or sets the internally created id of the group
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Items">
            <summary>
            Gets or sets ListViewItems that are members of this group
            </summary>
            <remarks>Listener of the BeforeCreatingGroups event can populate this collection.
            It is only used on non-virtual lists.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Key">
            <summary>
            Gets or sets the key that was used to partition objects into this group
            </summary>
            <remarks>This is user defined (like Tag)</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.ListView">
            <summary>
            Gets the ObjectListView that this group belongs to
            </summary>
            <remarks>If this is null, the group has not yet been created.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Name">
            <summary>
            Gets or sets the name of the group
            </summary>
            <remarks>As of 2009-09-01, this property is not used.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Focused">
            <summary>
            Gets or sets whether this group is focused
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Selected">
            <summary>
            Gets or sets whether this group is selected
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.SubsetTitle">
            <summary>
            Gets or sets the text that will show that this group is subsetted
            </summary>
            <remarks>
            As of WinSDK v7.0, subsetting of group is officially unimplemented.
            We can get around this using undocumented interfaces and may do so.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Subtitle">
            <summary>
            Gets or set the subtitleof the task
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.SortValue">
            <summary>
            Gets or sets the value by which this group will be sorted.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.State">
            <summary>
            Gets or sets the state of the group
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.StateMask">
            <summary>
            Gets or sets which bits of State are valid
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Subseted">
            <summary>
            Gets or sets whether this group is showing only a subset of its elements
            </summary>
            <remarks>
            As of WinSDK v7.0, this property officially does nothing.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Tag">
            <summary>
            Gets or sets the user-defined data attached to this group
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.Task">
            <summary>
            Gets or sets the task of this group
            </summary>
            <remarks>This task is the clickable text that appears on the right margin
            of the group header.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.TitleImage">
            <summary>
            Gets or sets the int or string that will select the image to be shown against the title
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.TopDescription">
            <summary>
            Gets or sets the top description of the group
            </summary>
            <remarks>
            Descriptions only appear when group is centered and there is a title image
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.VirtualItemCount">
            <summary>
            Gets or sets the number of items that are within this group.
            </summary>
            <remarks>This should only be used for virtual groups.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVGroup.ListViewGroup">
            <summary>
            Gets or sets the ListViewGroup that is shadowed by this group.
            </summary>
            <remarks>For virtual groups, this will always be null.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.HeaderControl">
            <summary>
            Class used to capture window messages for the header of the list view
            control.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.#ctor(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Create a header control for the given ObjectListView.
            </summary>
            <param name="olv"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.CalculateHeight(System.Drawing.Graphics)">
            <summary>
            Calculate how height the header needs to be
            </summary>
            <returns>Height in pixels</returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HasSortIndicator(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Should the given column show a sort indicator?
            </summary>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HasFilterIndicator(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Should the given column be drawn with a filter indicator against it?
            </summary>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HasNonThemedSortIndicator(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Should the given column show a non-themed sort indicator?
            </summary>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.GetItemRect(System.Int32)">
            <summary>
            Return the bounds of the item with the given index
            </summary>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.Invalidate">
            <summary>
            Force the header to redraw by invalidating it
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.CreateToolTip">
            <summary>
            Create a native tool tip control for this listview
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.WndProc(System.Windows.Forms.Message@)">
            <summary>
            Override the basic message pump
            </summary>
            <param name="m"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HandleSetCursor(System.Windows.Forms.Message@)">
            <summary>
            Handle the SetCursor windows message
            </summary>
            <param name="m"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HandleMouseMove(System.Windows.Forms.Message@)">
            <summary>
            Handle the MouseMove windows message
            </summary>
            <param name="m"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HandleNotify(System.Windows.Forms.Message@)">
            <summary>
            Handle the Notify windows message
            </summary>
            <param name="m"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HandleHeaderCustomDraw(System.Windows.Forms.Message@)">
            <summary>
            Handle the CustomDraw windows message
            </summary>
            <param name="m"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HandleLayout(System.Windows.Forms.Message@)">
            <summary>
            The message divides a ListView's space between the header and the rows of the listview.
            The WINDOWPOS structure controls the headers bounds, the RECT controls the listview bounds.
            </summary>
            <param name="m"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.HandleDestroy(System.Windows.Forms.Message@)">
            <summary>
            Handle when the underlying header control is destroyed
            </summary>
            <param name="m"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.NeedsCustomDraw">
            <summary>
            Does this header need to be custom drawn?
            </summary>
            <remarks>Word wrapping and colored text require custom drawning. Funnily enough, we
            can change the font natively.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.CustomDrawHeaderCell(System.Drawing.Graphics,System.Int32,System.Int32)">
            <summary>
            Draw one cell of the header
            </summary>
            <param name="g"></param>
            <param name="columnIndex"></param>
            <param name="itemState"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.DrawUnthemedBackground(System.Drawing.Graphics,System.Drawing.Rectangle,System.Int32,System.Boolean,BrightIdeasSoftware.HeaderStateStyle)">
            <summary>
            Draw a background for the header, without using Themes.
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="columnIndex"></param>
            <param name="isSelected"></param>
            <param name="stateStyle"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.DrawThemedBackground(System.Drawing.Graphics,System.Drawing.Rectangle,System.Int32,System.Boolean)">
            <summary>
            Draw a more-or-less pure themed header background.
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="columnIndex"></param>
            <param name="isSelected"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.DrawThemedSortIndicator(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw a sort indicator using themes
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.DrawUnthemedSortIndicator(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw a sort indicator without using themes
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.DrawFilterIndicator(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw an indication that this column has a filter applied to it
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.DrawHeaderImageAndText(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVColumn,BrightIdeasSoftware.HeaderStateStyle)">
            <summary>
            Draw the header's image and text
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="column"></param>
            <param name="stateStyle"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.CalculateStyle(BrightIdeasSoftware.OLVColumn,System.Boolean,System.Boolean)">
            <summary>
            What style should be applied to the header?
            </summary>
            <param name="column"></param>
            <param name="isHot"></param>
            <param name="isPressed"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderControl.CalculateFont(BrightIdeasSoftware.OLVColumn,System.Boolean,System.Boolean)">
            <summary>
            What font should be used to draw the header text?
            </summary>
            <param name="column"></param>
            <param name="isHot"></param>
            <param name="isPressed"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.ColumnIndexUnderCursor">
            <summary>
            Return the index of the column under the current cursor position,
            or -1 if the cursor is not over a column
            </summary>
            <returns>Index of the column under the cursor, or -1</returns>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.Handle">
            <summary>
            Return the Windows handle behind this control
            </summary>
            <remarks>
            When an ObjectListView is initialized as part of a UserControl, the
            GetHeaderControl() method returns 0 until the UserControl is
            completely initialized. So the AssignHandle() call in the constructor
            doesn't work. So we override the Handle property so value is always
            current.
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.HotFontStyle">
            <summary>
            Gets or sets a style that should be applied to the font of the
            column's header text when the mouse is over that column
            </summary>
            <remarks>THIS IS EXPERIMENTAL. USE AT OWN RISK. August 2009</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.IsCursorOverLockedDivider">
            <summary>
            Gets whether the cursor is over a "locked" divider, i.e.
            one that cannot be dragged by the user.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.ListView">
            <summary>
            Gets or sets the listview that this header belongs to
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.MaximumHeight">
            <summary>
            Gets the maximum height of the header. -1 means no maximum.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.ToolTip">
            <summary>
            Get or set the ToolTip that shows tips for the header
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.WordWrap">
            <summary>
            Gets or sets whether the text in column headers should be word
            wrapped when it is too long to fit within the column
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderControl.TextFormatFlags">
            <summary>
            What flags will be used when drawing text
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CellEditAtEdgeBehaviour">
            <summary>
            Indicates the behavior of a key when a cell "on the edge" is being edited.
            and the normal behavior of that key would exceed the edge. For example,
            for a key that normally moves one column to the left, the "edge" would be 
            the left most column, since the normal action of the key cannot be taken
            (since there are no more columns to the left).
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditAtEdgeBehaviour.Ignore">
            <summary>
            The key press will be ignored
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditAtEdgeBehaviour.Wrap">
            <summary>
            The key press will result in the cell editing wrapping to the 
            cell on the opposite edge.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditAtEdgeBehaviour.ChangeColumn">
            <summary>
            The key press will wrap, but the column will be changed to the 
            appropiate adjacent column. This only makes sense for keys where
            the normal action is ChangeRow.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditAtEdgeBehaviour.ChangeRow">
            <summary>
            The key press will wrap, but the row will be changed to the 
            appropiate adjacent row. This only makes sense for keys where
            the normal action is ChangeColumn.
            </summary>        
        </member>
        <member name="F:BrightIdeasSoftware.CellEditAtEdgeBehaviour.EndEdit">
            <summary>
            The key will result in the current edit operation being ended.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CellEditCharacterBehaviour">
            <summary>
            Indicates the normal behaviour of a key when used during a cell edit
            operation.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.Ignore">
            <summary>
            The key press will be ignored
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.ChangeColumnLeft">
            <summary>
            The key press will end the current edit and begin an edit
            operation on the next editable cell to the left.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.ChangeColumnRight">
            <summary>
            The key press will end the current edit and begin an edit
            operation on the next editable cell to the right.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.ChangeRowUp">
            <summary>
            The key press will end the current edit and begin an edit
            operation on the row above.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.ChangeRowDown">
            <summary>
            The key press will end the current edit and begin an edit
            operation on the row below
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CancelEdit">
            <summary>
            The key press will cancel the current edit
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.EndEdit">
            <summary>
            The key press will finish the current edit operation
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb1">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb2">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb3">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb4">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb5">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb6">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb7">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb8">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb9">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.CellEditCharacterBehaviour.CustomVerb10">
            <summary>
            Custom verb that can be used for specialized actions.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.CellEditKeyEngine">
            <summary>
            Instances of this class handle key presses during a cell edit operation.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.SetKeyBehaviour(System.Windows.Forms.Keys,BrightIdeasSoftware.CellEditCharacterBehaviour,BrightIdeasSoftware.CellEditAtEdgeBehaviour)">
            <summary>
            Sets the behaviour of a given key
            </summary>
            <param name="key"></param>
            <param name="normalBehaviour"></param>
            <param name="atEdgeBehaviour"></param>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.HandleKey(BrightIdeasSoftware.ObjectListView,System.Windows.Forms.Keys)">
            <summary>
            Handle a key press
            </summary>
            <param name="olv"></param>
            <param name="keyData"></param>
            <returns>True if the key was completely handled.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.InitializeCellEditKeyMaps">
            <summary>
            Setup the default key mapping
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.HandleEndEdit">
            <summary>
            Handle the end edit command
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.HandleCancelEdit">
            <summary>
            Handle the cancel edit command
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.HandleCustomVerb(System.Windows.Forms.Keys,BrightIdeasSoftware.CellEditCharacterBehaviour)">
            <summary>
            Placeholder that subclasses can override to handle any custom verbs
            </summary>
            <param name="keyData"></param>
            <param name="behaviour"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.HandleRowChange(System.Windows.Forms.Keys,BrightIdeasSoftware.CellEditCharacterBehaviour)">
            <summary>
            Handle a change row command
            </summary>
            <param name="keyData"></param>
            <param name="behaviour"></param>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.HandleColumnChange(System.Windows.Forms.Keys,BrightIdeasSoftware.CellEditCharacterBehaviour)">
            <summary>
            Handle a change column command
            </summary>
            <param name="keyData"></param>
            <param name="behaviour"></param>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.StartCellEditIfDifferent(BrightIdeasSoftware.OLVListItem,System.Int32)">
            <summary>
            Start editing the indicated cell if that cell is not already being edited
            </summary>
            <param name="olvi">The row to edit</param>
            <param name="subItemIndex">The cell within that row to edit</param>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.GetAdjacentItemOrNull(BrightIdeasSoftware.OLVListItem,System.Boolean)">
            <summary>
            Gets the adjacent item to the given item in the given direction.
            If that item is disabled, continue in that direction until an enabled item is found.
            </summary>
            <param name="olvi">The row whose neighbour is sought</param>
            <param name="up">The direction of the adjacentness</param>
            <returns>An OLVListView adjacent to the given item, or null if there are no more enabled items in that direction.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.CellEditKeyEngine.GetAdjacentItem(BrightIdeasSoftware.OLVListItem,System.Boolean)">
            <summary>
            Gets the adjacent item to the given item in the given direction, wrapping if needed.
            </summary>
            <param name="olvi">The row whose neighbour is sought</param>
            <param name="up">The direction of the adjacentness</param>
            <returns>An OLVListView adjacent to the given item, or null if there are no more items in that direction.</returns>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditKeyEngine.ListView">
            <summary>
            Gets or sets the ObjectListView on which the current key is being handled.
            This cannot be null.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditKeyEngine.ItemBeingEdited">
            <summary>
            Gets the row of the cell that is currently being edited
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditKeyEngine.SubItemIndexBeingEdited">
            <summary>
            Gets the index of the column of the cell that is being edited
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditKeyEngine.CellEditKeyMap">
            <summary>
            Gets or sets the map that remembers the normal behaviour of keys
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditKeyEngine.CellEditKeyAtEdgeBehaviourMap">
            <summary>
            Gets or sets the map that remembers the desired behaviour of keys 
            on edge cases.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellEditKeyEngine.EditableColumnsInDisplayOrder">
            <summary>
            Gets a collection of columns that are editable in the order they are shown to the user
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.Munger">
            <summary>
            An instance of Munger gets a value from or puts a value into a target object. The property
            to be peeked (or poked) is determined from a string. The peeking or poking is done using reflection.
            </summary>
            <remarks>
            Name of the aspect to be peeked can be a field, property or parameterless method. The name of an
            aspect to poke can be a field, writable property or single parameter method.
            <para>
            Aspect names can be dotted to chain a series of references. 
            </para>
            <example>Order.Customer.HomeAddress.State</example>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.Munger.#ctor">
            <summary>
            Create a do nothing Munger
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.Munger.#ctor(System.String)">
            <summary>
            Create a Munger that works on the given aspect name
            </summary>
            <param name="aspectName">The name of the </param>
        </member>
        <member name="M:BrightIdeasSoftware.Munger.PutProperty(System.Object,System.String,System.Object)">
            <summary>
            A helper method to put the given value into the given aspect of the given object.
            </summary>
            <remarks>This method catches and silently ignores any errors that occur
            while modifying the target object</remarks>
            <param name="target">The object to be modified</param>
            <param name="propertyName">The name of the property/field to be modified</param>
            <param name="value">The value to be assigned</param>
            <returns>Did the modification work?</returns>
        </member>
        <member name="M:BrightIdeasSoftware.Munger.GetValue(System.Object)">
            <summary>
            Extract the value indicated by our AspectName from the given target.
            </summary>
            <remarks>If the aspect name is null or empty, this will return null.</remarks>
            <param name="target">The object that will be peeked</param>
            <returns>The value read from the target</returns>
        </member>
        <member name="M:BrightIdeasSoftware.Munger.GetValueEx(System.Object)">
            <summary>
            Extract the value indicated by our AspectName from the given target, raising exceptions
            if the munger fails.
            </summary>
            <remarks>If the aspect name is null or empty, this will return null.</remarks>
            <param name="target">The object that will be peeked</param>
            <returns>The value read from the target</returns>
        </member>
        <member name="M:BrightIdeasSoftware.Munger.PutValue(System.Object,System.Object)">
            <summary>
            Poke the given value into the given target indicated by our AspectName.
            </summary>
            <remarks>
            <para>
            If the AspectName is a dotted path, all the selectors bar the last
            are used to find the object that should be updated, and the last
            selector is used as the property to update on that object.
            </para>
            <para>
            So, if 'target' is a Person and the AspectName is "HomeAddress.Postcode",
            this method will first fetch "HomeAddress" property, and then try to set the
            "Postcode" property on the home address object.
            </para>
            </remarks>
            <param name="target">The object that will be poked</param>
            <param name="value">The value that will be poked into the target</param>
            <returns>bool indicating whether the put worked</returns>
        </member>
        <member name="M:BrightIdeasSoftware.Munger.BuildParts(System.String)">
            <summary>
            Convert a possibly dotted AspectName into a list of SimpleMungers
            </summary>
            <param name="aspect"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Munger.EvaluateParts(System.Object,System.Collections.Generic.IList{BrightIdeasSoftware.SimpleMunger})">
            <summary>
            Evaluate the given chain of SimpleMungers against an initial target.
            </summary>
            <param name="target"></param>
            <param name="parts"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.Munger.IgnoreMissingAspects">
            <summary>
            Gets or sets whether Mungers will silently ignore missing aspect errors.
            </summary>
            <remarks>
            <para>
            By default, if a Munger is asked to fetch a field/property/method
            that does not exist from a model, it returns an error message, since that 
            condition is normally a programming error. There are some use cases where
            this is not an error, and the munger should simply keep quiet.
            </para>
            <para>By default this is true during release builds.</para>
            </remarks>
        </member>
        <member name="P:BrightIdeasSoftware.Munger.AspectName">
            <summary>
            The name of the aspect that is to be peeked or poked.
            </summary>
            <remarks>
            <para>
            This name can be a field, property or parameter-less method.
            </para>
            <para>
            The name can be dotted, which chains references. If any link in the chain returns
            null, the entire chain is considered to return null.
            </para>
            </remarks>
            <example>"DateOfBirth"</example>
            <example>"Owner.HomeAddress.Postcode"</example>
        </member>
        <member name="P:BrightIdeasSoftware.Munger.Parts">
            <summary>
            Gets the list of SimpleMungers that match our AspectName
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.SimpleMunger">
            <summary>
            A SimpleMunger deals with a single property/field/method on its target.
            </summary>
            <remarks>
            Munger uses a chain of these resolve a dotted aspect name.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleMunger.#ctor(System.String)">
            <summary>
            Create a SimpleMunger
            </summary>
            <param name="aspectName"></param>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleMunger.GetValue(System.Object)">
            <summary>
            Get a value from the given target
            </summary>
            <param name="target"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.SimpleMunger.PutValue(System.Object,System.Object)">
            <summary>
            Poke the given value into the given target indicated by our AspectName.
            </summary>
            <param name="target">The object that will be poked</param>
            <param name="value">The value that will be poked into the target</param>
            <returns>bool indicating if the put worked</returns>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleMunger.AspectName">
            <summary>
            The name of the aspect that is to be peeked or poked.
            </summary>
            <remarks>
            <para>
            This name can be a field, property or method. 
            When using a method to get a value, the method must be parameter-less.
            When using a method to set a value, the method must accept 1 parameter.
            </para>
            <para>
            It cannot be a dotted name.
            </para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.MungerException">
            <summary>
            These exceptions are raised when a munger finds something it cannot process
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.MungerException.#ctor(BrightIdeasSoftware.SimpleMunger,System.Object,System.Exception)">
            <summary>
            Create a MungerException
            </summary>
            <param name="munger"></param>
            <param name="target"></param>
            <param name="ex"></param>
        </member>
        <member name="P:BrightIdeasSoftware.MungerException.Munger">
            <summary>
            Get the munger that raised the exception
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.MungerException.Target">
            <summary>
            Gets the target that threw the exception
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.NativeMethods">
            <summary>
            Wrapper for all native method calls on ListView controls
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.SetBackgroundImage(System.Windows.Forms.ListView,System.Drawing.Image,System.Boolean,System.Boolean,System.Int32,System.Int32)">
            <summary>
            Put an image under the ListView.
            </summary>
            <remarks>
            <para>
            The ListView must have its handle created before calling this.
            </para>
            <para>
            This doesn't work very well. Specifically, it doesn't play well with owner drawn, 
            and grid lines are drawn over it.
            </para>
            </remarks>
            <param name="lv"></param>
            <param name="image">The image to be used as the background. If this is null, any existing background image will be cleared.</param>
            <param name="isWatermark">If this is true, the image is pinned to the bottom right and does not scroll. The other parameters are ignored</param>
            <param name="isTiled">If this is true, the image will be tiled to fill the whole control background. The offset parameters will be ignored.</param>
            <param name="xOffset">If both watermark and tiled are false, this indicates the horizontal percentage where the image will be placed. 0 is absolute left, 100 is absolute right.</param>
            <param name="yOffset">If both watermark and tiled are false, this indicates the vertical percentage where the image will be placed.</param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.DrawImage(System.Windows.Forms.ImageList,System.IntPtr,System.Int32,System.Int32,System.Int32,BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants,System.Int32,System.Int32,BrightIdeasSoftware.NativeMethods.ImageListDrawStateConstants)">
            <summary>
            Draws an image using the specified flags and state on XP systems.
            </summary>
            <param name="il">The image list from which an item will be drawn</param>
            <param name="hdc">Device context to draw to</param>
            <param name="index">Index of image to draw</param>
            <param name="x">X Position to draw at</param>
            <param name="y">Y Position to draw at</param>
            <param name="flags">Drawing flags</param>
            <param name="cx">Width to draw</param>
            <param name="cy">Height to draw</param>
            <param name="stateFlags">State flags</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.ForceSubItemImagesExStyle(System.Windows.Forms.ListView)">
            <summary>
            Make sure the ListView has the extended style that says to display subitem images.
            </summary>
            <remarks>This method must be called after any .NET call that update the extended styles
            since they seem to erase this setting.</remarks>
            <param name="list">The listview to send a m to</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.SetItemCount(System.Windows.Forms.ListView,System.Int32)">
            <summary>
            Change the virtual list size of the given ListView (which must be in virtual mode)
            </summary>
            <remarks>This will not change the scroll position</remarks>
            <param name="list">The listview to send a message to</param>
            <param name="count">How many rows should the list have?</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.SetExtendedStyle(System.Windows.Forms.ListView,System.Int32,System.Int32)">
            <summary>
            Make sure the ListView has the extended style that says to display subitem images.
            </summary>
            <remarks>This method must be called after any .NET call that update the extended styles
            since they seem to erase this setting.</remarks>
            <param name="list">The listview to send a m to</param>
            <param name="style"></param>
            <param name="styleMask"></param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.GetCountPerPage(System.Windows.Forms.ListView)">
            <summary>
            Calculates the number of items that can fit vertically in the visible area of a list-view (which
            must be in details or list view.
            </summary>
            <param name="list">The listView</param>
            <returns>Number of visible items per page</returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.SetSubItemImage(System.Windows.Forms.ListView,System.Int32,System.Int32,System.Int32)">
            <summary>
            For the given item and subitem, make it display the given image
            </summary>
            <param name="list">The listview to send a m to</param>
            <param name="itemIndex">row number (0 based)</param>
            <param name="subItemIndex">subitem (0 is the item itself)</param>
            <param name="imageIndex">index into the image list</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.SetColumnImage(System.Windows.Forms.ListView,System.Int32,System.Windows.Forms.SortOrder,System.Int32)">
            <summary>
            Setup the given column of the listview to show the given image to the right of the text.
            If the image index is -1, any previous image is cleared
            </summary>
            <param name="list">The listview to send a m to</param>
            <param name="columnIndex">Index of the column to modifiy</param>
            <param name="order"></param>
            <param name="imageIndex">Index into the small image list</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.HasBuiltinSortIndicators">
            <summary>
            Does this version of the operating system have builtin sort indicators?
            </summary>
            <returns>Are there builtin sort indicators</returns>
            <remarks>XP and later have these</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.GetUpdateRect(System.Windows.Forms.Control)">
            <summary>
            Return the bounds of the update region on the given control.
            </summary>
            <remarks>The BeginPaint() system call validates the update region, effectively wiping out this information.
            So this call has to be made before the BeginPaint() call.</remarks>
            <param name="cntl">The control whose update region is be calculated</param>
            <returns>A rectangle</returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.ValidateRect(System.Windows.Forms.Control,System.Drawing.Rectangle)">
            <summary>
            Validate an area of the given control. A validated area will not be repainted at the next redraw.
            </summary>
            <param name="cntl">The control to be validated</param>
            <param name="r">The area of the control to be validated</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.SelectAllItems(System.Windows.Forms.ListView)">
            <summary>
            Select all rows on the given listview
            </summary>
            <param name="list">The listview whose items are to be selected</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.DeselectAllItems(System.Windows.Forms.ListView)">
            <summary>
            Deselect all rows on the given listview
            </summary>
            <param name="list">The listview whose items are to be deselected</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.DeselectOneItem(System.Windows.Forms.ListView,System.Int32)">
            <summary>
            Deselect a single row
            </summary>
            <param name="list"></param>
            <param name="index"></param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.SetItemState(System.Windows.Forms.ListView,System.Int32,System.Int32,System.Int32)">
            <summary>
            Set the item state on the given item
            </summary>
            <param name="list">The listview whose item's state is to be changed</param>
            <param name="itemIndex">The index of the item to be changed</param>
            <param name="mask">Which bits of the value are to be set?</param>
            <param name="value">The value to be set</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.Scroll(System.Windows.Forms.ListView,System.Int32,System.Int32)">
            <summary>
            Scroll the given listview by the given deltas
            </summary>
            <param name="list"></param>
            <param name="dx"></param>
            <param name="dy"></param>
            <returns>true if the scroll succeeded</returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.GetHeaderControl(System.Windows.Forms.ListView)">
            <summary>
            Return the handle to the header control on the given list
            </summary>
            <param name="list">The listview whose header control is to be returned</param>
            <returns>The handle to the header control</returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.GetColumnSides(BrightIdeasSoftware.ObjectListView,System.Int32)">
            <summary>
            Return the edges of the given column.
            </summary>
            <param name="lv"></param>
            <param name="columnIndex"></param>
            <returns>A Point holding the left and right co-ords of the column.
            -1 means that the sides could not be retrieved.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.GetScrolledColumnSides(System.Windows.Forms.ListView,System.Int32)">
            <summary>
            Return the edges of the given column.
            </summary>
            <param name="lv"></param>
            <param name="columnIndex"></param>
            <returns>A Point holding the left and right co-ords of the column.
            -1 means that the sides could not be retrieved.</returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.GetColumnUnderPoint(System.IntPtr,System.Drawing.Point)">
            <summary>
            Return the index of the column of the header that is under the given point.
            Return -1 if no column is under the pt
            </summary>
            <param name="handle">The list we are interested in</param>
            <param name="pt">The client co-ords</param>
            <returns>The index of the column under the point, or -1 if no column header is under that point</returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.GetDividerUnderPoint(System.IntPtr,System.Drawing.Point)">
            <summary>
            Return the index of the divider under the given point. Return -1 if no divider is under the pt
            </summary>
            <param name="handle">The list we are interested in</param>
            <param name="pt">The client co-ords</param>
            <returns>The index of the divider under the point, or -1 if no divider is under that point</returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.GetScrollPosition(System.Windows.Forms.ListView,System.Boolean)">
            <summary>
            Get the scroll position of the given scroll bar
            </summary>
            <param name="lv"></param>
            <param name="horizontalBar"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.ChangeZOrder(System.Windows.Forms.IWin32Window,System.Windows.Forms.IWin32Window)">
            <summary>
            Change the z-order to the window 'toBeMoved' so it appear directly on top of 'reference'
            </summary>
            <param name="toBeMoved"></param>
            <param name="reference"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.MakeTopMost(System.Windows.Forms.IWin32Window)">
            <summary>
            Make the given control/window a topmost window
            </summary>
            <param name="toBeMoved"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.ShowWithoutActivate(System.Windows.Forms.IWin32Window)">
            <summary>
            Show the given window without activating it
            </summary>
            <param name="win">The window to show</param>
        </member>
        <member name="M:BrightIdeasSoftware.NativeMethods.SetSelectedColumn(System.Windows.Forms.ListView,System.Windows.Forms.ColumnHeader)">
            <summary>
            Mark the given column as being selected.
            </summary>
            <param name="objectListView"></param>
            <param name="value">The OLVColumn or null to clear</param>
            <remarks>
            This method works, but it prevents subitems in the given column from having
            back colors. 
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants">
            <summary>
            Flags controlling how the Image List item is 
            drawn
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_NORMAL">
            <summary>
            Draw item normally.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_TRANSPARENT">
            <summary>
            Draw item transparently.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_BLEND25">
            <summary>
            Draw item blended with 25% of the specified foreground colour
            or the Highlight colour if no foreground colour specified.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_SELECTED">
            <summary>
            Draw item blended with 50% of the specified foreground colour
            or the Highlight colour if no foreground colour specified.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_MASK">
            <summary>
            Draw the icon's mask
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_IMAGE">
            <summary>
            Draw the icon image without using the mask
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_ROP">
            <summary>
            Draw the icon using the ROP specified.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_PRESERVEALPHA">
            <summary>
            Preserves the alpha channel in dest. XP only.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_SCALE">
            <summary>
            Scale the image to cx, cy instead of clipping it. XP only.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawItemConstants.ILD_DPISCALE">
            <summary>
            Scale the image to the current DPI of the display. XP only.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.NativeMethods.ImageListDrawStateConstants">
            <summary>
            Enumeration containing XP ImageList Draw State options
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawStateConstants.ILS_NORMAL">
            <summary>
            The image state is not modified. 
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawStateConstants.ILS_GLOW">
            <summary>
            Adds a glow effect to the icon, which causes the icon to appear to glow 
            with a given color around the edges. (Note: does not appear to be implemented)
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawStateConstants.ILS_SHADOW">
            <summary>
            Adds a drop shadow effect to the icon. (Note: does not appear to be implemented)
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawStateConstants.ILS_SATURATE">
            <summary>
            Saturates the icon by increasing each color component 
            of the RGB triplet for each pixel in the icon. (Note: only ever appears to result in a completely unsaturated icon)
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.NativeMethods.ImageListDrawStateConstants.ILS_ALPHA">
            <summary>
            Alpha blends the icon. Alpha blending controls the transparency 
            level of an icon, according to the value of its alpha channel. 
            (Note: does not appear to be implemented).
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ColumnComparer">
            <summary>
            ColumnComparer is the workhorse for all comparison between two values of a particular column.
            If the column has a specific comparer, use that to compare the values. Otherwise, do
            a case insensitive string compare of the string representations of the values.
            </summary>
            <remarks><para>This class inherits from both IComparer and its generic counterpart
            so that it can be used on untyped and typed collections.</para></remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnComparer.#ctor(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Create a ColumnComparer that will order the rows in a list view according
            to the values in a given column
            </summary>
            <param name="col">The column whose values will be compared</param>
            <param name="order">The ordering for column values</param>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnComparer.#ctor(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Create a ColumnComparer that will order the rows in a list view according
            to the values in a given column, and by a secondary column if the primary
            column is equal.
            </summary>
            <param name="col">The column whose values will be compared</param>
            <param name="order">The ordering for column values</param>
            <param name="col2">The column whose values will be compared for secondary sorting</param>
            <param name="order2">The ordering for secondary column values</param>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnComparer.Compare(System.Object,System.Object)">
            <summary>
            Compare two rows
            </summary>
            <param name="x">row1</param>
            <param name="y">row2</param>
            <returns>An ordering indication: -1, 0, 1</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnComparer.Compare(BrightIdeasSoftware.OLVListItem,BrightIdeasSoftware.OLVListItem)">
            <summary>
            Compare two rows
            </summary>
            <param name="x">row1</param>
            <param name="y">row2</param>
            <returns>An ordering indication: -1, 0, 1</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ColumnComparer.CompareValues(System.Object,System.Object)">
            <summary>
            Compare the actual values to be used for sorting
            </summary>
            <param name="x">The aspect extracted from the first row</param>
            <param name="y">The aspect extracted from the second row</param>
            <returns>An ordering indication: -1, 0, 1</returns>
        </member>
        <member name="T:BrightIdeasSoftware.OLVGroupComparer">
            <summary>
            This comparer sort list view groups. OLVGroups have a "SortValue" property,
            which is used if present. Otherwise, the titles of the groups will be compared.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroupComparer.#ctor(System.Windows.Forms.SortOrder)">
            <summary>
            Create a group comparer
            </summary>
            <param name="order">The ordering for column values</param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVGroupComparer.Compare(BrightIdeasSoftware.OLVGroup,BrightIdeasSoftware.OLVGroup)">
            <summary>
            Compare the two groups. OLVGroups have a "SortValue" property,
            which is used if present. Otherwise, the titles of the groups will be compared.
            </summary>
            <param name="x">group1</param>
            <param name="y">group2</param>
            <returns>An ordering indication: -1, 0, 1</returns>
        </member>
        <member name="T:BrightIdeasSoftware.ModelObjectComparer">
            <summary>
            This comparer can be used to sort a collection of model objects by a given column
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ModelObjectComparer.#ctor(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Create a model object comparer
            </summary>
            <param name="col"></param>
            <param name="order"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ModelObjectComparer.#ctor(BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder,BrightIdeasSoftware.OLVColumn,System.Windows.Forms.SortOrder)">
            <summary>
            Create a model object comparer with a secondary sorting column
            </summary>
            <param name="col"></param>
            <param name="order"></param>
            <param name="col2"></param>
            <param name="order2"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ModelObjectComparer.Compare(System.Object,System.Object)">
            <summary>
            Compare the two model objects
            </summary>
            <param name="x"></param>
            <param name="y"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.ModelObjectComparer.CompareValues(System.Object,System.Object)">
            <summary>
            Compare the actual values
            </summary>
            <param name="x"></param>
            <param name="y"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.Design.ObjectListViewDesigner">
            <summary>
            Designer for <see cref="T:BrightIdeasSoftware.ObjectListView"/> and its subclasses.
            </summary>
            <remarks>
            <para>
            This designer removes properties and events that are available on ListView but that are not
            useful on ObjectListView.
            </para>
            <para>
            We can't inherit from System.Windows.Forms.Design.ListViewDesigner, since it is marked internal.
            So, this class uses reflection to create a ListViewDesigner and then forwards messages to that designer.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.Initialize(System.ComponentModel.IComponent)">
            <summary>
            Initializes the designer with the specified component.
            </summary>
            <param name="component">The <see cref="T:System.ComponentModel.IComponent"/> to associate the designer with. This component must always be an instance of, or derive from, <see cref="T:System.Windows.Forms.Control"/>. </param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.InitializeNewComponent(System.Collections.IDictionary)">
            <summary>
            Initializes a newly created component.
            </summary>
            <param name="defaultValues">A name/value dictionary of default values to apply to properties. May be null if no default values are specified.</param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.Dispose(System.Boolean)">
            <summary>
            Releases the unmanaged resources used by the <see cref="T:System.Windows.Forms.Design.ControlDesigner"/> and optionally releases the managed resources.
            </summary>
            <param name="disposing">true to release both managed and unmanaged resources; false to release only unmanaged resources. </param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.RemoveDuplicateDockingActionList">
            <summary>
            Removes the duplicate DockingActionList added by this designer to the <see cref="T:System.ComponentModel.Design.DesignerActionService"/>.
            </summary>
            <remarks>
            <see cref="M:System.Windows.Forms.Design.ControlDesigner.Initialize(System.ComponentModel.IComponent)"/> adds an internal DockingActionList : 'Dock/Undock in Parent Container'.
            But the default designer has already added that action list. So we need to remove one.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.PreFilterProperties(System.Collections.IDictionary)">
            <summary>
            Adjusts the set of properties the component exposes through a <see cref="T:System.ComponentModel.TypeDescriptor"/>.
            </summary>
            <param name="properties">An <see cref="T:System.Collections.IDictionary"/> containing the properties for the class of the component. </param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.PreFilterEvents(System.Collections.IDictionary)">
            <summary>
            Allows a designer to add to the set of events that it exposes through a <see cref="T:System.ComponentModel.TypeDescriptor"/>.
            </summary>
            <param name="events">The events for the class of the component. </param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.PostFilterAttributes(System.Collections.IDictionary)">
            <summary>
            Allows a designer to change or remove items from the set of attributes that it exposes through a <see cref="T:System.ComponentModel.TypeDescriptor"/>.
            </summary>
            <param name="attributes">The attributes for the class of the component. </param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.PostFilterEvents(System.Collections.IDictionary)">
            <summary>
            Allows a designer to change or remove items from the set of events that it exposes through a <see cref="T:System.ComponentModel.TypeDescriptor"/>.
            </summary>
            <param name="events">The events for the class of the component. </param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.GetHitTest(System.Drawing.Point)">
            <summary>
            Indicates whether a mouse click at the specified point should be handled by the control.
            </summary>
            <returns>
            true if a click at the specified point is to be handled by the control; otherwise, false.
            </returns>
            <param name="point">A <see cref="T:System.Drawing.Point"/> indicating the position at which the mouse was clicked, in screen coordinates. </param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.ObjectListViewDesigner.WndProc(System.Windows.Forms.Message@)">
            <summary>
            Processes Windows messages and optionally routes them to the control.
            </summary>
            <param name="m">The <see cref="T:System.Windows.Forms.Message"/> to process. </param>
        </member>
        <member name="P:BrightIdeasSoftware.Design.ObjectListViewDesigner.ActionLists">
            <summary>
            Gets the design-time action lists supported by the component associated with the designer.
            </summary>
            <returns>
            The design-time action lists supported by the component associated with the designer.
            </returns>
        </member>
        <member name="P:BrightIdeasSoftware.Design.ObjectListViewDesigner.AssociatedComponents">
            <summary>
            Gets the collection of components associated with the component managed by the designer.
            </summary>
            <returns>
            The components that are associated with the component managed by the designer.
            </returns>
        </member>
        <member name="T:BrightIdeasSoftware.Design.ObjectListViewDesigner.ListViewActionListAdapter">
            <summary>
            This class modifies a ListViewActionList, by removing the "Edit Items" and "Edit Groups" actions.
            </summary>
            <remarks>
            <para>
            That class is internal, so we cannot simply subclass it, which would be simplier.
            </para>
            <para>
            Action lists use reflection to determine if that action can be executed, so we not
            only have to modify the returned collection of actions, but we have to implement
            the properties and commands that the returned actions use. </para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.Design.OLVColumnCollectionEditor">
            <summary>
            This class works in conjunction with the OLVColumns property to allow OLVColumns
            to be added to the ObjectListView.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.Design.OLVColumnCollectionEditor.#ctor(System.Type)">
            <summary>
            Create a OLVColumnCollectionEditor
            </summary>
            <param name="t"></param>
        </member>
        <member name="M:BrightIdeasSoftware.Design.OLVColumnCollectionEditor.CreateCollectionItemType">
            <summary>
            What type of object does this editor create?
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Design.OLVColumnCollectionEditor.EditValue(System.ComponentModel.ITypeDescriptorContext,System.IServiceProvider,System.Object)">
            <summary>
            Edit a given value
            </summary>
            <param name="context"></param>
            <param name="provider"></param>
            <param name="value"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.Design.OLVColumnCollectionEditor.GetDisplayText(System.Object)">
            <summary>
            What text should be shown in the list for the given object?
            </summary>
            <param name="value"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.Design.OverlayConverter">
            <summary>
            Control how the overlay is presented in the IDE
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ITransparentOverlay">
            <summary>
            An interface for an overlay that supports variable levels of transparency
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ITransparentOverlay.Transparency">
            <summary>
            Gets or sets the transparency of the overlay. 
            0 is completely transparent, 255 is completely opaque.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractOverlay">
            <summary>
            A null implementation of the IOverlay interface
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractOverlay.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw this overlay
            </summary>
            <param name="olv">The ObjectListView that is being overlaid</param>
            <param name="g">The Graphics onto the given OLV</param>
            <param name="r">The content area of the OLV</param>
        </member>
        <member name="P:BrightIdeasSoftware.AbstractOverlay.Transparency">
            <summary>
            How transparent should this overlay be?
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ImageOverlay">
            <summary>
            An overlay that will draw an image over the top of the ObjectListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageOverlay.#ctor">
            <summary>
            Create an ImageOverlay
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageOverlay.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw this overlay
            </summary>
            <param name="olv">The ObjectListView being decorated</param>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
        </member>
        <member name="P:BrightIdeasSoftware.ImageOverlay.InsetX">
            <summary>
            Gets or sets the horizontal inset by which the position of the overlay will be adjusted
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ImageOverlay.InsetY">
            <summary>
            Gets or sets the vertical inset by which the position of the overlay will be adjusted
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TextOverlay">
            <summary>
            An overlay that will draw text over the top of the ObjectListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextOverlay.#ctor">
            <summary>
            Create a TextOverlay
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.TextOverlay.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw this overlay
            </summary>
            <param name="olv">The ObjectListView being decorated</param>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
        </member>
        <member name="P:BrightIdeasSoftware.TextOverlay.InsetX">
            <summary>
            Gets or sets the horizontal inset by which the position of the overlay will be adjusted
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextOverlay.InsetY">
            <summary>
            Gets or sets the vertical inset by which the position of the overlay will be adjusted
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TextOverlay.RoundCorneredBorder">
            <summary>
            Gets or sets whether the border will be drawn with rounded corners
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.BillboardOverlay">
            <summary>
            A Billboard overlay is a TextOverlay positioned at an absolute point
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BillboardOverlay.#ctor">
            <summary>
            Create a BillboardOverlay
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BillboardOverlay.Draw(BrightIdeasSoftware.ObjectListView,System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw this overlay
            </summary>
            <param name="olv">The ObjectListView being decorated</param>
            <param name="g">The Graphics used for drawing</param>
            <param name="r">The bounds of the rendering</param>
        </member>
        <member name="P:BrightIdeasSoftware.BillboardOverlay.Location">
            <summary>
            Gets or sets where should the top left of the billboard be placed
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.Version1Renderer">
            <summary>
            This class provides compatibility for v1 RendererDelegates
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.Version1Renderer.RenderDelegate">
            <summary>
            The renderer delegate that this renderer wraps
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.MappedImageRenderer">
            <summary>
            This class maps a data value to an image that should be drawn for that value.
            </summary>
            <remarks><para>It is useful for drawing data that is represented as an enum or boolean.</para></remarks>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.Boolean(System.Object,System.Object)">
            <summary>
            Return a renderer that draw boolean values using the given images
            </summary>
            <param name="trueImage">Draw this when our data value is true</param>
            <param name="falseImage">Draw this when our data value is false</param>
            <returns>A Renderer</returns>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.TriState(System.Object,System.Object,System.Object)">
            <summary>
            Return a renderer that draw tristate boolean values using the given images
            </summary>
            <param name="trueImage">Draw this when our data value is true</param>
            <param name="falseImage">Draw this when our data value is false</param>
            <param name="nullImage">Draw this when our data value is null</param>
            <returns>A Renderer</returns>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.#ctor">
            <summary>
            Make a new empty renderer
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.#ctor(System.Object,System.Object)">
            <summary>
            Make a new renderer that will show the given image when the given key is the aspect value
            </summary>
            <param name="key">The data value to be matched</param>
            <param name="image">The image to be shown when the key is matched</param>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.#ctor(System.Object,System.Object,System.Object,System.Object)">
            <summary>
            Make a new renderer that will show the given images when it receives the given keys
            </summary>
            <param name="key1"></param>
            <param name="image1"></param>
            <param name="key2"></param>
            <param name="image2"></param>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.#ctor(System.Object[])">
            <summary>
            Build a renderer from the given array of keys and their matching images
            </summary>
            <param name="keysAndImages">An array of key/image pairs</param>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.Add(System.Object,System.Object)">
            <summary>
            Register the image that should be drawn when our Aspect has the data value.
            </summary>
            <param name="value">Value that the Aspect must match</param>
            <param name="image">An ImageSelector -- an int, string or image</param>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Render our value
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.RenderCollection(System.Drawing.Graphics,System.Drawing.Rectangle,System.Collections.ICollection)">
            <summary>
            Draw a collection of images
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="imageSelectors"></param>
        </member>
        <member name="M:BrightIdeasSoftware.MappedImageRenderer.RenderOne(System.Drawing.Graphics,System.Drawing.Rectangle,System.Object)">
            <summary>
            Draw one image
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="selector"></param>
        </member>
        <member name="T:BrightIdeasSoftware.CheckStateRenderer">
            <summary>
            This renderer draws just a checkbox to match the check state of our model object.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.CheckStateRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our cell
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.CheckStateRenderer.HandleGetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            Handle the GetEditRectangle request
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.CheckStateRenderer.HandleHitTest(System.Drawing.Graphics,BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            Handle the HitTest request
            </summary>
            <param name="g"></param>
            <param name="hti"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="T:BrightIdeasSoftware.ImageRenderer">
            <summary>
            Render an image that comes from our data source.
            </summary>
            <remarks>The image can be sourced from:
            <list type="bullet">
            <item><description>a byte-array (normally when the image to be shown is
            stored as a value in a database)</description></item>
            <item><description>an int, which is treated as an index into the image list</description></item>
            <item><description>a string, which is treated first as a file name, and failing that as an index into the image list</description></item>
            <item><description>an ICollection of ints or strings, which will be drawn as consecutive images</description></item>
            </list>
            <para>If an image is an animated GIF, it's state is stored in the SubItem object.</para>
            <para>By default, the image renderer does not render animations (it begins life with animations paused).
            To enable animations, you must call Unpause().</para>
            <para>In the current implementation (2009-09), each column showing animated gifs must have a 
            different instance of ImageRenderer assigned to it. You cannot share the same instance of
            an image renderer between two animated gif columns. If you do, only the last column will be
            animated.</para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.#ctor">
            <summary>
            Make an empty image renderer
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.#ctor(System.Boolean)">
            <summary>
            Make an empty image renderer that begins life ready for animations
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.Dispose(System.Boolean)">
            <summary>
            Finalizer
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.Pause">
            <summary>
            Pause any animations
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.Unpause">
            <summary>
            Unpause any animations
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our image
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.GetImageFromAspect">
             <summary>
             Translate our Aspect into an image.
             </summary>
             <remarks>The strategy is:<list type="bullet">
             <item><description>If its a byte array, we treat it as an in-memory image</description></item>
             <item><description>If it's an int, we use that as an index into our image list</description></item>
             <item><description>If it's a string, we try to load a file by that name. If we can't, 
             we use the string as an index into our image list.</description></item>
            </list></remarks>
             <returns>An image</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.OnTimer(System.Object)">
            <summary>
            This is the method that is invoked by the timer. It basically switches control to the listview thread.
            </summary>
            <param name="state">not used</param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.OnTimerInThread">
            <summary>
            This is the OnTimer callback, but invoked in the same thread as the creator of the ListView.
            This method can use all of ListViews methods without creating a CrossThread exception.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ImageRenderer.Paused">
            <summary>
            Should the animations in this renderer be paused?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ImageRenderer.Tickler">
            <summary>
            Gets a timer that can be used to trigger redraws on animations
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ImageRenderer.AnimationState">
            <summary>
            Instances of this class kept track of the animation state of a single image.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.AnimationState.IsAnimation(System.Drawing.Image)">
            <summary>
            Is the given image an animation
            </summary>
            <param name="image">The image to be tested</param>
            <returns>Is the image an animation?</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.AnimationState.#ctor">
            <summary>
            Create an AnimationState in a quiet state
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.AnimationState.#ctor(System.Drawing.Image)">
            <summary>
            Create an animation state for the given image, which may or may not
            be an animation
            </summary>
            <param name="image">The image to be rendered</param>
        </member>
        <member name="M:BrightIdeasSoftware.ImageRenderer.AnimationState.AdvanceFrame(System.Int64)">
            <summary>
            Advance our images current frame and calculate when it will expire
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ImageRenderer.AnimationState.IsValid">
            <summary>
            Does this state represent a valid animation
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.BarRenderer">
            <summary>
            Render our Aspect as a progress bar
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.#ctor">
            <summary>
            Make a BarRenderer
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.#ctor(System.Int32,System.Int32)">
            <summary>
            Make a BarRenderer for the given range of data values
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.#ctor(System.Drawing.Pen,System.Drawing.Brush)">
            <summary>
            Make a BarRenderer using a custom bar scheme
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.#ctor(System.Int32,System.Int32,System.Drawing.Pen,System.Drawing.Brush)">
            <summary>
            Make a BarRenderer using a custom bar scheme
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.#ctor(System.Drawing.Pen,System.Drawing.Color,System.Drawing.Color)">
            <summary>
            Make a BarRenderer that uses a horizontal gradient
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.#ctor(System.Int32,System.Int32,System.Drawing.Pen,System.Drawing.Color,System.Drawing.Color)">
            <summary>
            Make a BarRenderer that uses a horizontal gradient
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.SetGradient(System.Drawing.Color,System.Drawing.Color)">
            <summary>
            Draw this progress bar using a gradient
            </summary>
            <param name="start"></param>
            <param name="end"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our aspect
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.BarRenderer.HandleGetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            Handle the GetEditRectangle request
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.UseStandardBar">
            <summary>
            Should this bar be drawn in the system style?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.Padding">
            <summary>
            How many pixels in from our cell border will this bar be drawn
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.BackgroundColor">
            <summary>
            What color will be used to fill the interior of the control before the 
            progress bar is drawn?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.FrameColor">
            <summary>
            What color should the frame of the progress bar be?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.FrameWidth">
            <summary>
            How many pixels wide should the frame of the progress bar be?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.FillColor">
            <summary>
            What color should the 'filled in' part of the progress bar be?
            </summary>
            <remarks>This is only used if GradientStartColor is Color.Empty</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.GradientStartColor">
            <summary>
            Use a gradient to fill the progress bar starting with this color
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.GradientEndColor">
            <summary>
            Use a gradient to fill the progress bar ending with this color
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.MaximumWidth">
            <summary>
            Regardless of how wide the column become the progress bar will never be wider than this
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.MaximumHeight">
            <summary>
            Regardless of how high the cell is  the progress bar will never be taller than this
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.MinimumValue">
            <summary>
            The minimum data value expected. Values less than this will given an empty bar
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.MaximumValue">
            <summary>
            The maximum value for the range. Values greater than this will give a full bar
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.Pen">
            <summary>
            The Pen that will draw the frame surrounding this bar
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.Brush">
            <summary>
            The brush that will be used to fill the bar
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.BarRenderer.BackgroundBrush">
            <summary>
            The brush that will be used to fill the background of the bar
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ImagesRenderer">
            <summary>
            An ImagesRenderer draws zero or more images depending on the data returned by its Aspect.
            </summary>
            <remarks><para>This renderer's Aspect must return a ICollection of ints, strings or Images,
            each of which will be drawn horizontally one after the other.</para>
            <para>As of v2.1, this functionality has been absorbed into ImageRenderer and this is now an
            empty shell, solely for backwards compatibility.</para>
            </remarks>
        </member>
        <member name="T:BrightIdeasSoftware.MultiImageRenderer">
            <summary>
            A MultiImageRenderer draws the same image a number of times based on our data value
            </summary>
            <remarks><para>The stars in the Rating column of iTunes is a good example of this type of renderer.</para></remarks>
        </member>
        <member name="M:BrightIdeasSoftware.MultiImageRenderer.#ctor">
            <summary>
            Make a quiet rendererer
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.MultiImageRenderer.#ctor(System.Object,System.Int32,System.Int32,System.Int32)">
            <summary>
            Make an image renderer that will draw the indicated image, at most maxImages times.
            </summary>
            <param name="imageSelector"></param>
            <param name="maxImages"></param>
            <param name="minValue"></param>
            <param name="maxValue"></param>
        </member>
        <member name="M:BrightIdeasSoftware.MultiImageRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our data value
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.MultiImageRenderer.HandleGetEditRectangle(System.Drawing.Graphics,System.Drawing.Rectangle,BrightIdeasSoftware.OLVListItem,System.Int32,System.Drawing.Size)">
            <summary>
            Handle the GetEditRectangle request
            </summary>
            <param name="g"></param>
            <param name="cellBounds"></param>
            <param name="item"></param>
            <param name="subItemIndex"></param>
            <param name="preferredSize"> </param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.MultiImageRenderer.ImageIndex">
            <summary>
            The index of the image that should be drawn
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.MultiImageRenderer.ImageName">
            <summary>
            The name of the image that should be drawn
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.MultiImageRenderer.ImageSelector">
            <summary>
            The image selector that will give the image to be drawn
            </summary>
            <remarks>Like all image selectors, this can be an int, string or Image</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.MultiImageRenderer.MaxNumberImages">
            <summary>
            What is the maximum number of images that this renderer should draw?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.MultiImageRenderer.MinimumValue">
            <summary>
            Values less than or equal to this will have 0 images drawn
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.MultiImageRenderer.MaximumValue">
            <summary>
            Values greater than or equal to this will have MaxNumberImages images drawn
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.FlagRenderer">
            <summary>
            A class to render a value that contains a bitwise-OR'ed collection of values.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.FlagRenderer.Add(System.Object,System.Object)">
            <summary>
            Register the given image to the given value
            </summary>
            <param name="key">When this flag is present...</param>
            <param name="imageSelector">...draw this image</param>
        </member>
        <member name="M:BrightIdeasSoftware.FlagRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw the flags
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.FlagRenderer.HandleHitTest(System.Drawing.Graphics,BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            Do the actual work of hit testing. Subclasses should override this rather than HitTest()
            </summary>
            <param name="g"></param>
            <param name="hti"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="T:BrightIdeasSoftware.DescribedTaskRenderer">
            <summary>
            This renderer draws an image, a single line title, and then multi-line descrition
            under the title.
            </summary>
            <remarks>
            <para>This class works best with FullRowSelect = true.</para>
            <para>It's not designed to work with cell editing -- it will work but will look odd.</para>
            <para>
            This class is experimental. It may not work properly and may disappear from
            future versions.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.DescribedTaskRenderer.#ctor">
            <summary>
            Create a DescribedTaskRenderer
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.DescribedTaskRenderer.GetDescription">
            <summary>
            Fetch the description from the model class
            </summary>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.DescribedTaskRenderer.Render(System.Drawing.Graphics,System.Drawing.Rectangle)">
            <summary>
            Draw our item
            </summary>
            <param name="g"></param>
            <param name="r"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DescribedTaskRenderer.DrawDescribedTask(System.Drawing.Graphics,System.Drawing.Rectangle,System.String,System.String,System.Drawing.Image)">
            <summary>
            Draw the task
            </summary>
            <param name="g"></param>
            <param name="r"></param>
            <param name="title"></param>
            <param name="description"></param>
            <param name="image"></param>
        </member>
        <member name="M:BrightIdeasSoftware.DescribedTaskRenderer.HandleHitTest(System.Drawing.Graphics,BrightIdeasSoftware.OlvListViewHitTestInfo,System.Int32,System.Int32)">
            <summary>
            Handle the HitTest request
            </summary>
            <param name="g"></param>
            <param name="hti"></param>
            <param name="x"></param>
            <param name="y"></param>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.TitleFont">
            <summary>
            Gets or set the font that will be used to draw the title of the task
            </summary>
            <remarks>If this is null, the ListView's font will be used</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.TitleFontOrDefault">
            <summary>
            Return a font that has been set for the title or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.TitleColor">
            <summary>
            Gets or set the color of the title of the task
            </summary>
            <remarks>This color is used when the task is not selected or when the listview
            has a translucent selection mechanism.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.TitleColorOrDefault">
            <summary>
            Return the color of the title of the task or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.DescriptionFont">
            <summary>
            Gets or set the font that will be used to draw the description of the task
            </summary>
            <remarks>If this is null, the ListView's font will be used</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.DescriptionFontOrDefault">
            <summary>
            Return a font that has been set for the title or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.DescriptionColor">
            <summary>
            Gets or set the color of the description of the task
            </summary>
            <remarks>This color is used when the task is not selected or when the listview
            has a translucent selection mechanism.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.DescriptionColorOrDefault">
            <summary>
            Return the color of the description of the task or a reasonable default
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.ImageTextSpace">
            <summary>
            Gets or sets the number of pixels that will be left between the image and the text
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.DescribedTaskRenderer.DescriptionAspectName">
            <summary>
            Gets or sets the name of the aspect of the model object that contains the task description
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.IItemStyle">
            <summary>
            The common interface supported by all style objects
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IItemStyle.Font">
            <summary>
            Gets or set the font that will be used by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IItemStyle.FontStyle">
            <summary>
            Gets or set the font style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IItemStyle.ForeColor">
            <summary>
            Gets or sets the ForeColor
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.IItemStyle.BackColor">
            <summary>
            Gets or sets the BackColor
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.SimpleItemStyle">
            <summary>
            Basic implementation of IItemStyle
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleItemStyle.Font">
            <summary>
            Gets or sets the font that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleItemStyle.FontStyle">
            <summary>
            Gets or sets the style of font that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleItemStyle.ForeColor">
            <summary>
            Gets or sets the color of the text that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.SimpleItemStyle.BackColor">
            <summary>
            Gets or sets the background color that will be applied by this style
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HotItemStyle">
            <summary>
            Instances of this class specify how should "hot items" (non-selected
            rows under the cursor) be renderered.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemStyle.Overlay">
            <summary>
            Gets or sets the overlay that should be drawn as part of the hot item
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HotItemStyle.Decoration">
            <summary>
            Gets or sets the decoration that should be drawn as part of the hot item
            </summary>
            <remarks>A decoration is different from an overlay in that an decoration
            scrolls with the listview contents, whilst an overlay does not.</remarks>
        </member>
        <member name="T:BrightIdeasSoftware.CellStyle">
            <summary>
            This class defines how a cell should be formatted
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellStyle.Font">
            <summary>
            Gets or sets the font that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellStyle.FontStyle">
            <summary>
            Gets or sets the style of font that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellStyle.ForeColor">
            <summary>
            Gets or sets the color of the text that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.CellStyle.BackColor">
            <summary>
            Gets or sets the background color that will be applied by this style
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HyperlinkStyle">
            <summary>
            Instances of this class describe how hyperlinks will appear
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HyperlinkStyle.#ctor">
            <summary>
            Create a HyperlinkStyle
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkStyle.Normal">
            <summary>
            What sort of formatting should be applied to hyperlinks in their normal state?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkStyle.Over">
            <summary>
            What sort of formatting should be applied to hyperlinks when the mouse is over them?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkStyle.Visited">
            <summary>
            What sort of formatting should be applied to hyperlinks after they have been clicked?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HyperlinkStyle.OverCursor">
            <summary>
            Gets or sets the cursor that should be shown when the mouse is over a hyperlink.
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HeaderStateStyle">
            <summary>
            Instances of this class control one the styling of one particular state
            (normal, hot, pressed) of a header control
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderStateStyle.Font">
            <summary>
            Gets or sets the font that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderStateStyle.ForeColor">
            <summary>
            Gets or sets the color of the text that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderStateStyle.BackColor">
            <summary>
            Gets or sets the background color that will be applied by this style
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderStateStyle.FrameColor">
            <summary>
            Gets or sets the color in which a frame will be drawn around the header for this column
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderStateStyle.FrameWidth">
            <summary>
            Gets or sets the width of the frame that will be drawn around the header for this column
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.HeaderFormatStyle">
            <summary>
            This class defines how a header should be formatted in its various states.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderFormatStyle.#ctor">
            <summary>
            Create a new HeaderFormatStyle
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderFormatStyle.SetFont(System.Drawing.Font)">
            <summary>
            Set the font for all three states
            </summary>
            <param name="font"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderFormatStyle.SetForeColor(System.Drawing.Color)">
            <summary>
            Set the fore color for all three states
            </summary>
            <param name="color"></param>
        </member>
        <member name="M:BrightIdeasSoftware.HeaderFormatStyle.SetBackColor(System.Drawing.Color)">
            <summary>
            Set the back color for all three states
            </summary>
            <param name="color"></param>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderFormatStyle.Hot">
            <summary>
            What sort of formatting should be applied to a column header when the mouse is over it?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderFormatStyle.Normal">
            <summary>
            What sort of formatting should be applied to a column header in its normal state?
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.HeaderFormatStyle.Pressed">
            <summary>
            What sort of formatting should be applied to a column header when pressed?
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ToolTipControl">
            <summary>
            A limited wrapper around a Windows tooltip window.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.TTN_SHOW">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.TTN_POP">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.TTN_LINKCLICK">
            <summary>
            
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.TTN_GETDISPINFO">
            <summary>
            
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.Create(System.IntPtr)">
            <summary>
            Create the underlying control.
            </summary>
            <param name="parentHandle">The parent of the tooltip</param>
            <remarks>This does nothing if the control has already been created</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.PushSettings">
            <summary>
            Take a copy of the current settings and restore them when the 
            tooltip is poppped.
            </summary>
            <remarks>
            This call cannot be nested. Subsequent calls to this method will be ignored
            until PopSettings() is called.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.PopSettings">
            <summary>
            Restore the settings of the tooltip as they were when PushSettings()
            was last called.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.AddTool(System.Windows.Forms.IWin32Window)">
            <summary>
            Add the given window to those for whom this tooltip will show tips
            </summary>
            <param name="window">The window</param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.PopToolTip(System.Windows.Forms.IWin32Window)">
            <summary>
            Hide any currently visible tooltip
            </summary>
            <param name="window"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.RemoveToolTip(System.Windows.Forms.IWin32Window)">
            <summary>
            Remove the given window from those managed by this tooltip
            </summary>
            <param name="window"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.SetMaxWidth">
            <summary>
            Set the maximum width of a tooltip string.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.SetMaxWidth(System.Int32)">
            <summary>
            Set the maximum width of a tooltip string.
            </summary>
            <remarks>Setting this ensures that line breaks in the tooltip are honoured.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.MakeToolInfoStruct(System.Windows.Forms.IWin32Window)">
            <summary>
            Make a TOOLINFO structure for the given window
            </summary>
            <param name="window"></param>
            <returns>A filled in TOOLINFO</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.HandleNotify(System.Windows.Forms.Message@)">
            <summary>
            Handle a WmNotify message
            </summary>
            <param name="msg">The msg</param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.HandleGetDispInfo(System.Windows.Forms.Message@)">
            <summary>
            Handle a get display info message
            </summary>
            <param name="msg">The msg</param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.HandleLinkClick(System.Windows.Forms.Message@)">
            <summary>
            Handle a TTN_LINKCLICK message
            </summary>
            <param name="msg">The msg</param>
            <returns>True if the message has been handled</returns>
            <remarks>This cannot call base.WndProc() since the msg may have come from another control.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.HandlePop(System.Windows.Forms.Message@)">
            <summary>
            Handle a TTN_POP message
            </summary>
            <param name="msg">The msg</param>
            <returns>True if the message has been handled</returns>
            <remarks>This cannot call base.WndProc() since the msg may have come from another control.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.HandleShow(System.Windows.Forms.Message@)">
            <summary>
            Handle a TTN_SHOW message
            </summary>
            <param name="msg">The msg</param>
            <returns>True if the message has been handled</returns>
            <remarks>This cannot call base.WndProc() since the msg may have come from another control.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.HandleReflectNotify(System.Windows.Forms.Message@)">
            <summary>
            Handle a reflected notify message
            </summary>
            <param name="msg">The msg</param>
            <returns>True if the message has been handled</returns>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.WndProc(System.Windows.Forms.Message@)">
            <summary>
            Mess with the basic message pump of the tooltip
            </summary>
            <param name="msg"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.OnShowing(BrightIdeasSoftware.ToolTipShowingEventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="M:BrightIdeasSoftware.ToolTipControl.OnPop(System.EventArgs)">
            <summary>
            
            </summary>
            <param name="e"></param>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.WindowStyle">
            <summary>
            Get or set if the style of the tooltip control
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.IsBalloon">
            <summary>
            Get or set if the tooltip should be shown as a ballon
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.HasBorder">
            <summary>
            Get or set if the tooltip should be shown as a ballon
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.BackColor">
            <summary>
            Get or set the background color of the tooltip
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.ForeColor">
            <summary>
            Get or set the color of the text and border on the tooltip.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.Title">
            <summary>
            Get or set the title that will be shown on the tooltip.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.StandardIcon">
            <summary>
            Get or set the icon that will be shown on the tooltip.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.Font">
            <summary>
            Gets or sets the font that will be used to draw this control.
            is still.
            </summary>
            <remarks>Setting this to null reverts to the default font.</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.AutoPopDelay">
            <summary>
            Gets or sets how many milliseconds the tooltip will remain visible while the mouse
            is still.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.InitialDelay">
            <summary>
            Gets or sets how many milliseconds the mouse must be still before the tooltip is shown.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.ToolTipControl.ReshowDelay">
            <summary>
            Gets or sets how many milliseconds the mouse must be still before the tooltip is shown again.
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ToolTipControl.Showing">
            <summary>
            Tell the world that a tooltip is about to show
            </summary>
        </member>
        <member name="E:BrightIdeasSoftware.ToolTipControl.Pop">
            <summary>
            Tell the world that a tooltip is about to disappear
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.ToolTipControl.StandardIcons">
            <summary>
            These are the standard icons that a tooltip can display.
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.StandardIcons.None">
            <summary>
            No icon
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.StandardIcons.Info">
            <summary>
            Info
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.StandardIcons.Warning">
            <summary>
            Warning
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.StandardIcons.Error">
            <summary>
            Error
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.StandardIcons.InfoLarge">
            <summary>
            Large info (Vista and later only)
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.StandardIcons.WarningLarge">
            <summary>
            Large warning (Vista and later only)
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.ToolTipControl.StandardIcons.ErrorLarge">
            <summary>
            Large error (Vista and later only)
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVExporter">
            <summary>
            An OLVExporter converts a collection of rows from an ObjectListView
            into a variety of textual formats.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVExporter.#ctor">
            <summary>
            Create an empty exporter
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVExporter.#ctor(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Create an exporter that will export all the rows of the given ObjectListView
            </summary>
            <param name="olv"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVExporter.#ctor(BrightIdeasSoftware.ObjectListView,System.Collections.IEnumerable)">
            <summary>
            Create an exporter that will export all the given rows from the given ObjectListView
            </summary>
            <param name="olv"></param>
            <param name="objectsToExport"></param>
        </member>
        <member name="M:BrightIdeasSoftware.OLVExporter.ExportTo(BrightIdeasSoftware.OLVExporter.ExportFormat)">
            <summary>
            Export the nominated rows from the nominated ObjectListView.
            Returns the result in the expected format.
            </summary>
            <param name="format"></param>
            <returns></returns>
            <remarks>This will perform only one conversion, even if called multiple times with different formats.</remarks>
        </member>
        <member name="M:BrightIdeasSoftware.OLVExporter.Convert">
            <summary>
            Convert 
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.OLVExporter.CsvEncode(System.String)">
            <summary>
            Encode a string such that it can be used as a value in a CSV file.
            This basically means replacing any quote mark with two quote marks,
            and enclosing the whole string in quotes.
            </summary>
            <param name="text"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.OLVExporter.HtmlEncode(System.String)">
            <summary>
            HTML-encodes a string and returns the encoded string.
            </summary>
            <param name="text">The text string to encode. </param>
            <returns>The HTML-encoded text.</returns>
            <remarks>Taken from http://www.west-wind.com/weblog/posts/2009/Feb/05/Html-and-Uri-String-Encoding-without-SystemWeb</remarks>
        </member>
        <member name="P:BrightIdeasSoftware.OLVExporter.IncludeHiddenColumns">
            <summary>
            Gets or sets whether hidden columns will also be included in the textual
            representation. If this is false (the default), only visible columns will
            be included.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVExporter.IncludeColumnHeaders">
            <summary>
            Gets or sets whether column headers will also be included in the text
            and HTML representation. Default is true.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVExporter.ListView">
            <summary>
            Gets the ObjectListView that is being used as the source of the data
            to be exported
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.OLVExporter.ModelObjects">
            <summary>
            Gets the model objects that are to be placed in the data object
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.OLVExporter.ExportFormat">
            <summary>
            What format will be used for exporting
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OLVExporter.ExportFormat.TabSeparated">
            <summary>
            Tab separated values, according to http://www.iana.org/assignments/media-types/text/tab-separated-values
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OLVExporter.ExportFormat.TSV">
            <summary>
            Alias for TabSeparated
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OLVExporter.ExportFormat.CSV">
            <summary>
            Comma separated values, according to http://www.ietf.org/rfc/rfc4180.txt
            </summary>
        </member>
        <member name="F:BrightIdeasSoftware.OLVExporter.ExportFormat.HTML">
            <summary>
            HTML table, according to me
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TypedObjectListView`1">
            <summary>
            A TypedObjectListView is a type-safe wrapper around an ObjectListView.
            </summary>
            <remarks>
            <para>VCS does not support generics on controls. It can be faked to some degree, but it
            cannot be completely overcome. In our case in particular, there is no way to create
            the custom OLVColumn's that we need to truly be generic. So this wrapper is an 
            experiment in providing some type-safe access in a way that is useful and available today.</para>
            <para>A TypedObjectListView is not more efficient than a normal ObjectListView.
            Underneath, the same name of casts are performed. But it is easier to use since you
            do not have to write the casts yourself.
            </para>
            </remarks>
            <typeparam name="T">The class of model object that the list will manage</typeparam>
            <example>
            To use a TypedObjectListView, you write code like this:
            <code>
            TypedObjectListView&lt;Person> tlist = new TypedObjectListView&lt;Person>(this.listView1);
            tlist.CheckStateGetter = delegate(Person x) { return x.IsActive; };
            tlist.GetColumn(0).AspectGetter = delegate(Person x) { return x.Name; };
            ...
            </code>
            To iterate over the selected objects, you can write something elegant like this:
            <code>
            foreach (Person x in tlist.SelectedObjects) {
                x.GrantSalaryIncrease();
            }
            </code>
            </example>
        </member>
        <member name="M:BrightIdeasSoftware.TypedObjectListView`1.#ctor(BrightIdeasSoftware.ObjectListView)">
            <summary>
            Create a typed wrapper around the given list.
            </summary>
            <param name="olv">The listview to be wrapped</param>
        </member>
        <member name="M:BrightIdeasSoftware.TypedObjectListView`1.GetColumn(System.Int32)">
            <summary>
            Return a typed wrapper around the column at the given index
            </summary>
            <param name="i">The index of the column</param>
            <returns>A typed column or null</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TypedObjectListView`1.GetColumn(System.String)">
            <summary>
            Return a typed wrapper around the column with the given name
            </summary>
            <param name="name">The name of the column</param>
            <returns>A typed column or null</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TypedObjectListView`1.GetModelObject(System.Int32)">
            <summary>
            Return the model object at the given index
            </summary>
            <param name="index">The index of the model object</param>
            <returns>The model object or null</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TypedObjectListView`1.GenerateAspectGetters">
            <summary>
            This method will generate AspectGetters for any column that has an AspectName.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.CheckedObject">
            <summary>
            Return the model object that is checked, if only one row is checked.
            If zero rows are checked, or more than one row, null is returned.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.CheckedObjects">
            <summary>
            Return the list of all the checked model objects
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.ListView">
            <summary>
            The ObjectListView that is being wrapped
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.Objects">
            <summary>
            Get or set the list of all model objects
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.SelectedObject">
            <summary>
            Return the model object that is selected, if only one row is selected.
            If zero rows are selected, or more than one row, null is returned.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.SelectedObjects">
            <summary>
            The list of model objects that are selected.
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.CheckStateGetter">
            <summary>
            Gets or sets the check state getter
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.BooleanCheckStateGetter">
            <summary>
            Gets or sets the boolean check state getter
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.CheckStatePutter">
            <summary>
            Gets or sets the check state putter delegate
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.BooleanCheckStatePutter">
            <summary>
            Gets or sets the boolean check state putter
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.CellToolTipGetter">
            <summary>
            Gets or sets the cell tooltip getter
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedObjectListView`1.HeaderToolTipGetter">
            <summary>
            Gets or sets the header tool tip getter
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TypedObjectListView`1.TypedCheckStateGetterDelegate">
            <summary>
            CheckStateGetter
            </summary>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.TypedObjectListView`1.TypedBooleanCheckStateGetterDelegate">
            <summary>
            BooleanCheckStateGetter
            </summary>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.TypedObjectListView`1.TypedCheckStatePutterDelegate">
            <summary>
            CheckStatePutter
            </summary>
            <param name="rowObject"></param>
            <param name="newValue"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.TypedObjectListView`1.TypedBooleanCheckStatePutterDelegate">
            <summary>
            BooleanCheckStatePutter
            </summary>
            <param name="rowObject"></param>
            <param name="newValue"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.TypedObjectListView`1.TypedCellToolTipGetterDelegate">
            <summary>
            ToolTipGetter
            </summary>
            <param name="column"></param>
            <param name="modelObject"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.TypedColumn`1">
            <summary>
            A type-safe wrapper around an OLVColumn
            </summary>
            <typeparam name="T"></typeparam>
        </member>
        <member name="M:BrightIdeasSoftware.TypedColumn`1.#ctor(BrightIdeasSoftware.OLVColumn)">
            <summary>
            Creates a TypedColumn
            </summary>
            <param name="column"></param>
        </member>
        <member name="M:BrightIdeasSoftware.TypedColumn`1.GenerateAspectGetter">
            <summary>
            Generate an aspect getter that does the same thing as the AspectName,
            except without using reflection.
            </summary>
            <remarks>
            <para>
            If you have an AspectName of "Owner.Address.Postcode", this will generate
            the equivilent of: <code>this.AspectGetter = delegate (object x) {
                return x.Owner.Address.Postcode;
            }
            </code>
            </para>
            <para>
            If AspectName is empty, this method will do nothing, otherwise 
            this will replace any existing AspectGetter.
            </para>
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.TypedColumn`1.GenerateAspectGetter(System.Type,System.String)">
            <summary>
            Generates an aspect getter method dynamically. The method will execute
            the given dotted chain of selectors against a model object given at runtime.
            </summary>
            <param name="type">The type of model object to be passed to the generated method</param>
            <param name="path">A dotted chain of selectors. Each selector can be the name of a 
            field, property or parameter-less method.</param>
            <returns>A typed delegate</returns>
        </member>
        <member name="M:BrightIdeasSoftware.TypedColumn`1.GenerateIL(System.Type,System.String,System.Reflection.Emit.ILGenerator)">
            <summary>
            This method generates the actual IL for the method.
            </summary>
            <param name="type"></param>
            <param name="path"></param>
            <param name="il"></param>
        </member>
        <member name="P:BrightIdeasSoftware.TypedColumn`1.AspectGetter">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedColumn`1.AspectPutter">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedColumn`1.ImageGetter">
            <summary>
            
            </summary>
        </member>
        <member name="P:BrightIdeasSoftware.TypedColumn`1.GroupKeyGetter">
            <summary>
            
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.TypedColumn`1.TypedAspectGetterDelegate">
            <summary>
            
            </summary>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.TypedColumn`1.TypedAspectPutterDelegate">
            <summary>
            
            </summary>
            <param name="rowObject"></param>
            <param name="newValue"></param>
        </member>
        <member name="T:BrightIdeasSoftware.TypedColumn`1.TypedGroupKeyGetterDelegate">
            <summary>
            
            </summary>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.TypedColumn`1.TypedImageGetterDelegate">
            <summary>
            
            </summary>
            <param name="rowObject"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.IVirtualGroups">
            <summary>
            A IVirtualGroups is the interface that a virtual list must implement to support virtual groups
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualGroups.GetGroups(BrightIdeasSoftware.GroupingParameters)">
            <summary>
            Return the list of groups that should be shown according to the given parameters
            </summary>
            <param name="parameters"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualGroups.GetGroupMember(BrightIdeasSoftware.OLVGroup,System.Int32)">
            <summary>
            Return the index of the item that appears at the given position within the given group.
            </summary>
            <param name="group"></param>
            <param name="indexWithinGroup"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualGroups.GetGroup(System.Int32)">
            <summary>
            Return the index of the group to which the given item belongs
            </summary>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualGroups.GetIndexWithinGroup(BrightIdeasSoftware.OLVGroup,System.Int32)">
            <summary>
            Return the index at which the given item is shown in the given group
            </summary>
            <param name="group"></param>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.IVirtualGroups.CacheHint(System.Int32,System.Int32,System.Int32,System.Int32)">
            <summary>
            A hint that the given range of items are going to be required
            </summary>
            <param name="fromGroupIndex"></param>
            <param name="fromIndex"></param>
            <param name="toGroupIndex"></param>
            <param name="toIndex"></param>
        </member>
        <member name="T:BrightIdeasSoftware.AbstractVirtualGroups">
            <summary>
            This is a safe, do nothing implementation of a grouping strategy
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualGroups.GetGroups(BrightIdeasSoftware.GroupingParameters)">
            <summary>
            Return the list of groups that should be shown according to the given parameters
            </summary>
            <param name="parameters"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualGroups.GetGroupMember(BrightIdeasSoftware.OLVGroup,System.Int32)">
            <summary>
            Return the index of the item that appears at the given position within the given group.
            </summary>
            <param name="group"></param>
            <param name="indexWithinGroup"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualGroups.GetGroup(System.Int32)">
            <summary>
            Return the index of the group to which the given item belongs
            </summary>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualGroups.GetIndexWithinGroup(BrightIdeasSoftware.OLVGroup,System.Int32)">
            <summary>
            Return the index at which the given item is shown in the given group
            </summary>
            <param name="group"></param>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.AbstractVirtualGroups.CacheHint(System.Int32,System.Int32,System.Int32,System.Int32)">
            <summary>
            A hint that the given range of items are going to be required
            </summary>
            <param name="fromGroupIndex"></param>
            <param name="fromIndex"></param>
            <param name="toGroupIndex"></param>
            <param name="toIndex"></param>
        </member>
        <member name="T:BrightIdeasSoftware.FastListGroupingStrategy">
            <summary>
            Provides grouping functionality to a FastObjectListView
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.FastListGroupingStrategy.GetGroups(BrightIdeasSoftware.GroupingParameters)">
            <summary>
            Create groups for FastListView
            </summary>
            <param name="parmameters"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FastListGroupingStrategy.GetGroupMember(BrightIdeasSoftware.OLVGroup,System.Int32)">
            <summary>
            
            </summary>
            <param name="group"></param>
            <param name="indexWithinGroup"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FastListGroupingStrategy.GetGroup(System.Int32)">
            <summary>
            
            </summary>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.FastListGroupingStrategy.GetIndexWithinGroup(BrightIdeasSoftware.OLVGroup,System.Int32)">
            <summary>
            
            </summary>
            <param name="group"></param>
            <param name="itemIndex"></param>
            <returns></returns>
        </member>
        <member name="T:BrightIdeasSoftware.IOwnerDataCallback">
            <summary>
            This is the COM interface that a ListView must be given in order for groups in virtual lists to work.
            </summary>
            <remarks>
            This interface is NOT documented by MS. It was found on Greg Chapell's site. This means that there is
            no guarantee that it will work on future versions of Windows, nor continue to work on current ones.
            </remarks>
        </member>
        <member name="M:BrightIdeasSoftware.IOwnerDataCallback.GetItemPosition(System.Int32,BrightIdeasSoftware.NativeMethods.POINT@)">
            <summary>
            Not sure what this does
            </summary>
            <param name="i"></param>
            <param name="pt"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IOwnerDataCallback.SetItemPosition(System.Int32,BrightIdeasSoftware.NativeMethods.POINT)">
            <summary>
            Not sure what this does
            </summary>
            <param name="t"></param>
            <param name="pt"></param>
        </member>
        <member name="M:BrightIdeasSoftware.IOwnerDataCallback.GetItemInGroup(System.Int32,System.Int32,System.Int32@)">
            <summary>
            Get the index of the item that occurs at the n'th position of the indicated group.
            </summary>
            <param name="groupIndex">Index of the group</param>
            <param name="n">Index within the group</param>
            <param name="itemIndex">Index of the item within the whole list</param>
        </member>
        <member name="M:BrightIdeasSoftware.IOwnerDataCallback.GetItemGroup(System.Int32,System.Int32,System.Int32@)">
            <summary>
            Get the index of the group to which the given item belongs
            </summary>
            <param name="itemIndex">Index of the item within the whole list</param>
            <param name="occurrenceCount">Which occurences of the item is wanted</param>
            <param name="groupIndex">Index of the group</param>
        </member>
        <member name="M:BrightIdeasSoftware.IOwnerDataCallback.GetItemGroupCount(System.Int32,System.Int32@)">
            <summary>
            Get the number of groups that contain the given item
            </summary>
            <param name="itemIndex">Index of the item within the whole list</param>
            <param name="occurrenceCount">How many groups does it occur within</param>
        </member>
        <member name="M:BrightIdeasSoftware.IOwnerDataCallback.OnCacheHint(BrightIdeasSoftware.NativeMethods.LVITEMINDEX,BrightIdeasSoftware.NativeMethods.LVITEMINDEX)">
            <summary>
            A hint to prepare any cache for the given range of requests
            </summary>
            <param name="i"></param>
            <param name="j"></param>
        </member>
        <member name="T:BrightIdeasSoftware.OwnerDataCallbackImpl">
            <summary>
            A default implementation of the IOwnerDataCallback interface
            </summary>
        </member>
        <member name="T:BrightIdeasSoftware.VirtualListVersion1DataSource">
            <summary>
            This class mimics the behavior of VirtualObjectListView v1.x.
            </summary>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualListVersion1DataSource.#ctor(BrightIdeasSoftware.VirtualObjectListView)">
            <summary>
            Creates a VirtualListVersion1DataSource
            </summary>
            <param name="listView"></param>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualListVersion1DataSource.GetNthObject(System.Int32)">
            <summary>
            
            </summary>
            <param name="n"></param>
            <returns></returns>
        </member>
        <member name="M:BrightIdeasSoftware.VirtualListVersion1DataSource.SearchText(System.String,System.Int32,System.Int32,BrightIdeasSoftware.OLVColumn)">
            <summary>
            
            </summary>
            <param name="value"></param>
            <param name="first"></param>
            <param name="last"></param>
            <param name="column"></param>
            <returns></returns>
        </member>
        <member name="P:BrightIdeasSoftware.VirtualListVersion1DataSource.RowGetter">
            <summary>
            How will the n'th object of the data source be fetched?
            </summary>
        </member>
    </members>
</doc>
